Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/spring/11.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 使用类似“OPE”的语法时,字符串到数字的转换失败?_Java_Spring_Spring Boot_Teradata - Fatal编程技术网

Java 使用类似“OPE”的语法时,字符串到数字的转换失败?

Java 使用类似“OPE”的语法时,字符串到数字的转换失败?,java,spring,spring-boot,teradata,Java,Spring,Spring Boot,Teradata,我尝试使用SpringJDBC模板运行这个查询 public static String FIND_CNC_OPE_GRAPPE_BY_FCT_ID = "SELECT " +"EXPO.COD_NAT_XPN " +", EXPO.IDF_TEC_XPN " +", EXPO.IDF_FCT_XPN_RIS " +

我尝试使用SpringJDBC模板运行这个查询

  public static String FIND_CNC_OPE_GRAPPE_BY_FCT_ID = 
        "SELECT "
                    +"EXPO.COD_NAT_XPN "
                    +", EXPO.IDF_TEC_XPN "
                    +", EXPO.IDF_FCT_XPN_RIS "
                    +", EXPO.DAT_PRM_IPE_LC_CEC  "
        +"FROM  T_CCA_EXPO EXPO "
        +"WHERE "
        + " 'OPE' = ? ";
为此,我使用以下java代码:

  import java.sql.Connection;
  import java.sql.PreparedStatement;
  import java.sql.ResultSet;
  import java.sql.SQLException;
  import java.util.ArrayList;
  import java.util.List;

  import org.apache.commons.lang3.StringUtils;
  import org.springframework.beans.factory.annotation.Autowired;
  import org.springframework.jdbc.core.JdbcTemplate;
  import org.springframework.stereotype.Repository;

  import lombok.extern.slf4j.Slf4j;

  @Repository
  @Slf4j
  public class ContractGrappeRepository implements ContractGrappeInterfaceRepository {

       static String query = GrappeQueryConstant.FIND_CNC_OPE_GRAPPE_BY_FCT_ID;

       @Autowired
       private JdbcTemplate baseJDBCTemplate;

       private Connection dbConnection;

       private PreparedStatement statement = null;

       private ResultSet dealResultSet;

       @Override
       public ResultSet findGrappeByDealFctID() {

       try {
          dbConnection = baseJDBCTemplate.getDataSource().getConnection();
          statement = dbConnection.prepareStatement(query);
          statement.setString(1,"AKA");
          dealResultSet = statement.executeQuery();
       } catch (SQLException e) {
          throw new RestructNumberException("Exception while fetching contracts",e);
       }

       return null; // TO MODIFY
   }

 }
编译器到达此行时,dbConnection.prepareStatementquery;我收到了这个错误信息

   java.sql.SQLException: [Teradata Database] [TeraJDBC 16.00.00.24] [Error 3535] [SQLState 22003] A character string failed conversion to a numeric value.
at com.teradata.jdbc.jdbc_4.util.ErrorFactory.makeDatabaseSQLException(ErrorFactory.java:309)
at com.teradata.jdbc.jdbc_4.statemachine.ReceiveInitSubState.action(ReceiveInitSubState.java:103)
at com.teradata.jdbc.jdbc_4.statemachine.StatementReceiveState.subStateMachine(StatementReceiveState.java:311)
at com.teradata.jdbc.jdbc_4.statemachine.StatementReceiveState.action(StatementReceiveState.java:200)
at com.teradata.jdbc.jdbc_4.statemachine.StatementController.runBody(StatementController.java:137)
at com.teradata.jdbc.jdbc_4.statemachine.StatementController.run(StatementController.java:128)
at com.teradata.jdbc.jdbc_4.TDStatement.executeStatement(TDStatement.java:389)
at com.teradata.jdbc.jdbc_4.TDStatement.prepareRequest(TDStatement.java:576)
at com.teradata.jdbc.jdbc_4.TDPreparedStatement.<init>(TDPreparedStatement.java:128)
at com.teradata.jdbc.jdk6.JDK6_SQL_PreparedStatement.<init>(JDK6_SQL_PreparedStatement.java:30)
at com.teradata.jdbc.jdk6.JDK6_SQL_Connection.constructPreparedStatement(JDK6_SQL_Connection.java:82)
at com.teradata.jdbc.jdbc_4.TDSession.prepareStatement(TDSession.java:1330)
at com.teradata.jdbc.jdbc_4.TDSession.prepareStatement(TDSession.java:1374)
at com.teradata.jdbc.jdbc_4.TDSession.prepareStatement(TDSession.java:1360)
at com.teradata.jdbc.jdbc.ManagerConnectionBase.prepareStatement(ManagerConnectionBase.java:294)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)

我没有任何错误

为什么java不接受这种语法“OPE”=

我使用的是Spring boot 1.5.9.0版本


Teradata版本16.00.00.24

更改语句。setString1,也称为setInt

编辑: 在

由于TeraData试图编译SQL查询时遵循了以下规则,所以出现了错误

对于你的问题,我找到了解决办法。您应该做的是更改查询,如下所示:

" 'OPE' = cast(? as number) ";
将JDBC对象放在ContractGrappeRepository的字段中是危险的;它们必须关闭,并且不能共享每个实例

   try (Connection dbConnection = baseJDBCTemplate.getDataSource().getConnection();
          Prepared statement = dbConnection.prepareStatement(query)) {
      statement.setString(1,"AKA");
      try (ResultSet dealResultSet = statement.executeQuery()) {
          while (dealResultSet.next()) {
              ...
          }
          return ...
      }
   } catch (SQLException e) {
      throw new RestructNumberException("Exception while fetching contracts",e);
   }
有一个概念上的错误:?是值的占位符,结果为

'OPE' = 'AKA'               ***WRONG***
因此,您需要一个列比较concatenate/String。格式化SQL字符串:

     statement = dbConnection.prepareStatement(query.replace("?", "AKA"));

是否尝试将列作为变量传递?并始终将其与字符串“OPE”进行比较?您不能保留语句;如果删除问号。根据您的SQL Assistant版本、连接方法和选项设置,SQLA可能会在将查询传递给SQL之前进行简单的文本替换。另一方面,绑定参数只能用于传递值,而不能更改标记,例如查询中使用的列名。因此,我不能在我的查询@Fred?@Andre中使用此语法。不,我尝试检查一个变量值,而不是列名作为变量。我收到了新的错误消息[error 3784][SQLState 42000]指定的位数必须介于1和38之间。当我使用这个“OPE”=cast时?第60号;,问题是不同的,java不接受'charsequence'=的语法?为什么使用60?我们可以使用介于1和38之间的数字吗?当我将38改为60[TeraJDBC 16.00.00.24][error 3535][SQLState 22003]时,出现了第一个错误。字符串无法转换为数值。“OPE”=“AKA”也不被接受,我现在测试了它!执行一个干净的构建,调试/记录查询值。选择EXPO.COD_NAT_XPN,EXPO.IDF_TEC_XPN,EXPO.IDF_FCT_XPN_RIS,EXPO.DAT_PRM_IPE_LC_CEC FROM T_CCA_EXPO EXPO,其中'OPE'='AKKA'如果AKA或AKKA是一个列名,那么SQL语法需要无引号或双引号。将值放在撇号单引号“”中表示字符串文字。你说不被接受是什么意思。如果您收到语法错误,请发布该错误。如果您收到了意外的结果,即没有行,则说明。no AKA不是列,它是一个简单的字符串,正如我所说的,当我尝试运行此示例查询时,我遇到了一个错误,字符串无法转换为数值。我的查询太长,有很多OR语句,但问题是'some string'='some string'
   try (Connection dbConnection = baseJDBCTemplate.getDataSource().getConnection();
          Prepared statement = dbConnection.prepareStatement(query)) {
      statement.setString(1,"AKA");
      try (ResultSet dealResultSet = statement.executeQuery()) {
          while (dealResultSet.next()) {
              ...
          }
          return ...
      }
   } catch (SQLException e) {
      throw new RestructNumberException("Exception while fetching contracts",e);
   }
'OPE' = 'AKA'               ***WRONG***
     statement = dbConnection.prepareStatement(query.replace("?", "AKA"));