Не удалось преобразовать символьную строку в цифру c при использовании синтаксиса типа «OPE» =? - PullRequest
3 голосов
/ 17 января 2020

Я пытаюсь выполнить этот запрос, используя Spring JDB C Шаблон

  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
   }

 }

Когда компилятор прибывает в этот line dbConnection.prepareStatement (query); я получил это сообщение об ошибке;

   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)

Когда я запускаю свой запрос на Terdata sql assistant, у меня не возникает никаких ошибок. но когда я изменяю в своем запросе выражение where

    +"WHERE "
    + " 'OPE' = ? ";

на

    +"WHERE "
    + " 'OPE' = EXP.COD_NAT_XPN ";

У меня нет ошибок,

Почему java нет принять этот синтаксис 'OPE' =?

Я использую Spring boot 1.5.9.RELEASE

Версия Teradata 16.00.00.24

Ответы [ 2 ]

0 голосов
/ 21 января 2020

Помещение объектов JDB C в поля 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***

Так вам нужно для сравнения столбцов / String.format SQL строка:

     statement = dbConnection.prepareStatement(query.replace("?", "AKA"));
0 голосов
/ 17 января 2020

Измените Statement.setString (1, "AKA") на setInt

Редактировать: в

statement = dbConnection.prepareStatement(query);

Вы получаете ошибку из-за следующего правила link , где TeraData пытается скомпилировать ваш SQL запрос.

Для вашей проблемы я нашел решение здесь . Что вы должны сделать, это изменить запрос, как показано ниже:

" 'OPE' = cast(? as number) ";
...