2011-03-01 140 views
1

我有一個問題並不總是出現,但它在大多數時間都這樣做。在我的巨大的java類的預測,我有一些結果集,當我執行程序我得到:SQLServerException無效的列名稱

com.microsoft.sqlserver.jdbc.SQLServerException: El nombre de columna DistanciaMision no es vßlido. 
    at com.microsoft.sqlserver.jdbc.SQLServerException.makeFromDriverError(SQLServerException.java:170) 
    at com.microsoft.sqlserver.jdbc.SQLServerResultSet.findColumn(SQLServerResultSet.java:626) 
    at com.microsoft.sqlserver.jdbc.SQLServerResultSet.getString(SQLServerResultSet.java:2301) 
    at es.csic.iiia.udt.itim.iInformation.WebData.Forecast.etaMSR(Forecast.java:1109) 
    at es.csic.iiia.udt.itim.iInformation.WebData.Forecast.phase2(Forecast.java:662) 
    at es.csic.iiia.udt.itim.iInformation.WebData.Forecast.setData(Forecast.java:166) 
    at es.csic.iiia.udt.itim.iInformation.WebData.Forecast.main(Forecast.java:81) 
    at es.csic.iiia.udt.itim.iInformation.WebData.Forecast.execute(Forecast.java:71) 
    at org.quartz.core.JobRunShell.run(JobRunShell.java:199) 
    at org.quartz.simpl.SimpleThreadPool$WorkerThread.run(SimpleThreadPool.java:546) 

列存在,所以我不知道是什麼問題...

代碼線是這一個:

Float distancia_restante = (float) (Integer.parseInt(rs.getString("DistanciaMision")) - (myodometer - initialodometer)); 

同樣的問題出現在其他列,但它通常在這裏崩潰。

謝謝!

編輯:好的,這是整個方法:

private static void etaMSR() throws Exception, SQLException { 
    /** 
    * 
    * Calculem ETAN MSR - Mision - Seguimiento - Restricciones conductor 
    * 
    * 
    **/ 

    System.out 
      .print("Get data from iTIM forecast&forecastAUX DDBB ....... "); 
    myStatement = MSSQLServerAccess.connection(); 

    // Distancia mision, ruta, hora mision anterior, hora 
    rs = getTable("SELECT  dbo.WebForecast.IdConductor, dbo.WebForecast.IdMision, dbo.WebForecast.IdMisionAnterior, dbo.WebForecast.DistanciaMision, " 
      + "      WebForecast_1.HoraIniMis AS himanterior, dbo.WebForecast.HoraFiMis AS hfmactual, WebForecast_1.Ciudad AS CiudadOrigen," 
      + "      dbo.WebForecast.Ciudad AS CiudadDestino, dbo.Distancias.Ruta, dbo.WebForecast.HoraDistancia AS HoraDistancia" 
      + " FROM   dbo.WebForecast AS WebForecast_1 INNER JOIN" 
      + "      dbo.Distancias ON WebForecast_1.Ciudad = dbo.Distancias.Origen RIGHT OUTER JOIN" 
      + "      dbo.WebForecast ON WebForecast_1.IdMision = dbo.WebForecast.IdMisionAnterior AND dbo.Distancias.Destino = dbo.WebForecast.Ciudad" 
      + " WHERE  (dbo.WebForecast.IdConductor <> '') AND (CONVERT(datetime, '" 
      + df.format(fechaDia) 
      + "') <= dbo.WebForecast.HoraFiMis) " 
      + " AND WebForecast_1.HoraIniMis <= CONVERT(datetime, '" 
      + df.format(fechaDia) + "') "); 
    System.out.println("[ok]"); 


    while (rs.next() && (rs.getString("IdConductor") != "") && org.apache.commons.lang.StringUtils.isNumeric(rs.getString("IdConductor"))) { 

     int initialodometer = 0; 
     String start = null; 

     if (rs.getString("HoraDistancia") != null) { 
      start = rs.getString("HoraDistancia"); 
     } 

     if (rs.getString("himanterior") != null) { 
      start = rs.getString("himanterior"); 
     } 

     if (start != null) { 
      ResultSet myrs = null; 
      Timestamp tobjetivo = rs.getTimestamp("himanterior"); 
      long boundtime = 7200000; // 3600000 = 60m = 1h 
      Timestamp tini = (Timestamp) rs.getTimestamp("himanterior") 
        .clone(); 
      Timestamp tfin = (Timestamp) rs.getTimestamp("himanterior") 
        .clone(); 
      tini.setTime(tini.getTime() - boundtime); 
      tfin.setTime(tfin.getTime() + boundtime); 
      int contador = 0; 

      long bestdiff = 0; 

      myStatement = MSSQLServerAccess.connection(); 
      myrs = getTable("SELECT DISTINCT Odometer, DT " 
        + "FROM DriverEvents " 
        + "WHERE (DT BETWEEN CONVERT(datetime, '" 
        + df.format(tini) + "') " + "AND CONVERT(datetime, '" 
        + df.format(tfin) + "')) " + "AND (CardId = '" 
        + Integer.parseInt(rs.getString("IdConductor")) + "')"); 

      int j = 0; 
      while (!myrs.next() && (j < 20)) { 
       // En caso de no encontrar en las 2h antes y despues nada: 
       tini.setTime(tini.getTime() - boundtime); 
       tfin.setTime(tfin.getTime() + boundtime); 

       myrs.close(); 
       myStatement = MSSQLServerAccess.connection(); 
       myrs = getTable("SELECT DISTINCT Odometer, DT " 
         + "FROM DriverEvents " 
         + "WHERE (DT BETWEEN CONVERT(datetime, '" 
         + df.format(tini) + "') " 
         + "AND CONVERT(datetime, '" + df.format(tfin) 
         + "')) " + "AND (CardId = '" 
         + Integer.parseInt(rs.getString("IdConductor")) 
         + "')"); 
       j++; 
      } 

      if (myrs.next()) { 
       initialodometer = myrs.getInt("Odometer"); 
       bestdiff = Math.abs(tobjetivo.getTime() 
         - myrs.getTimestamp("DT").getTime()); 
       contador++; 
       while (myrs.next()) { 
        long pretendiente = Math.abs(tobjetivo.getTime() 
          - myrs.getTimestamp("DT").getTime()); 
        if (pretendiente <= bestdiff) { 
         bestdiff = pretendiente; 
         initialodometer = myrs.getInt("Odometer"); 
        } 
        contador++; 
       } 

      } 
      myrs.close(); 
      } 

     // Get Odometer distance at the moment 

     if (!rs.getString("IdConductor").isEmpty() && !rs.getString("IdConductor").equals("")) { 
      ResultSet myrs = null; 
      int myodometer = 0; 

      myStatement = MSSQLServerAccess.connection(); 
      myrs = getTable("SELECT  MAX(DT) AS DT, MAX(Odometer) AS Odometer" 
        + " FROM   dbo.DriverEvents" 
        + " WHERE  (CardId = '" 
        + Integer.parseInt(rs.getString("IdConductor")) 
        + "') AND (DT > CONVERT(datetime, '" 
        + df.format(fechaDatos) + "')) "); 

      if (myrs.next()) { 
       myodometer = myrs.getInt("Odometer"); 
       if (initialodometer == 0) 
        initialodometer = myodometer; 

       Float distancia_restante = (float) (Integer.parseInt(rs.getString("DistanciaMision")) - (myodometer - initialodometer)); 
       if (distancia_restante < 0) 
        distancia_restante = (float) 0; 

       Timestamp ETAN = null; 
       Calendar cal = Calendar.getInstance(); 

       if (rs.getTimestamp("himanterior") != null && rs.getTimestamp("himanterior").toString() != "") { 

        cal.setTimeInMillis(rs.getTimestamp("himanterior") 
          .getTime()); 

        if (cal.after(Calendar.getInstance())) { 

         cal.setTimeInMillis(rs.getTimestamp("himanterior") 
           .getTime()); 
        } 

        if (cal.before(Calendar.getInstance())) { 
         cal = Calendar.getInstance(); 
        } 
       } else { 
        if (rs.getTimestamp("HoraDistancia") != null) 
         cal.setTimeInMillis(rs 
           .getTimestamp("HoraDistancia").getTime()); 

       } 

       myStatement = MSSQLServerAccess.connection(); 

       rs2 = getTable("SELECT  TOP (100) PERCENT CardId, DT" 
         + " FROM   dbo.DriverEvents" 
         + " GROUP BY CardId, DT" 
         + " HAVING  (CardId = '" 
         + Integer.parseInt(rs.getString("IdConductor")) 
         + "') AND (DT > CONVERT(datetime, '" 
         + df.format(fechaDatos) + "'))"); 

       if (rs2.next()) { 
        ETAN = getETAN(rs, distancia_restante, cal); 
       } else { 

        ETAN = getETA(rs, distancia_restante, cal, 1); 


       Statement myStatement2 = MSSQLServerAccess.connection(); 
       myStatement2.executeUpdate("UPDATE WebForecast " 
         + "SET ETAmsr = '" + df.format(ETAN) 
         + "', KmsDiff = '" + distancia_restante.intValue() 
         + "' " + "WHERE IdMision = '" 
         + rs.getString("IdMision") + "'"); 

      } else { 


      } 
     } 
    } 

    rs.close(); 
} 

和聲明,也許是我做錯了什麼?:

private static Statement conStatement(Properties properties){ 

    String driverName = "com.microsoft.sqlserver.jdbc.SQLServerDriver"; // Load the JDBC driver 
    String dbURL = "jdbc:sqlserver://" 
     + properties.getProperty("qualcomm.action.JDBC.MSSQLServerAccess.ddbbserverIP") 
     + ";DatabaseName=" 
     + properties.getProperty("qualcomm.action.JDBC.MSSQLServerAccess.ddbbName") 
     + ";SelectMethod=Cursor;"; // Connect to a server and database 
    String userName = properties.getProperty("qualcomm.action.JDBC.MSSQLServerAccess.userName"); 
    String userPwd = properties.getProperty("qualcomm.action.JDBC.MSSQLServerAccess.userPwd"); 
    Connection dbConn; 

    try { 
     Class.forName(driverName); 

     dbConn = DriverManager.getConnection(dbURL, userName, userPwd); 
     //log.info("Connection Successful!"); 
     Statement myst = dbConn.createStatement(); 

     return myst; 
    } catch (Exception e) { 
     log.error(e); 
     System.out.println(e); 
     return null; 
    } 
} 

謝謝你們:)可能是什麼問題該聲明?

+1

我們需要看到的是力量推動這個代碼查詢訪問它。對我來說,似乎該列可能存在,但它不會被特定的查詢返回。 – Toby 2011-03-01 15:04:20

+0

你是** 1000%**確定你沒有拼寫錯誤的列,或者你可能已經連接到一個沒有該列的數據庫的錯誤版本? – 2011-03-01 16:06:16

+0

當你說列存在時,但是代碼說不存在,那麼猜猜我們會相信誰? – 2011-03-01 18:12:25

回答

0

請記住,Java是區分大小寫的,因此您可以根據創建它們的方式在SQL上創建表,具體取決於數據庫上的排序規則。如果您的數據庫是使用區分大小寫歸類創建的,則所有對象名稱都將區分大小寫。

嘗試檢查SQL列的確切列名並使用[]和準確的情況下