SQL语法错误,同时使用java(eclipse)

时间:2014-05-08 09:33:35

标签: java mysql sql eclipse

我使用java eclipse和mySQL workbench来相互连接。现在我使用java来编写一些查询,但是在查询问题时遇到了一个特定的问题,我不熟悉这个错误,并且在做了几个sql查询后我第一次遇到问题。任何帮助表示赞赏。我将列出代码,然后跟进错误。

public static void stopTimes() throws SQLException
    {
    stmt = conn.createStatement();
    System.out.println("Enter Route Number: ");
    String route = scan.nextLine();
    System.out.println("Direction?");
    String dir = scan.nextLine();
    System.out.println("Enter the first stop number:");
    String stop1 = scan.nextLine();
    System.out.println("Enter the second stop number:");
String stop2 = scan.nextLine();      
String sql;

  sql = "SELECT DISTINCT bus_stops.stopID, street1, street2 FROM bus_stops INNER JOIN scheduled_stops ON bus_stops.stopID = scheduled_stops.stopID"+
              "WHERE scheduled_stops.routeNumber = '"+route+"' "+
              "AND scheduled_stops.direction = '"+dir+"' "+
              "AND scheduled_stops.stopTime > (SELECT stopTime FROM scheduled_stops WHERE scheduled_stops.stopID = '"+stop1+"' ORDER BY scheduled_stops.stopTime asc limit 1)"+ 
              "AND scheduled_stops.stopTime < (SELECT stopTime FROM scheduled_stops WHERE scheduled_stops.stopID = '"+stop2+"' ORDER BY scheduled_stops.stopTime asc limit 1)";


      ResultSet rs = stmt.executeQuery(sql);

      //STEP 5: Extract data from result set
      while(rs.next()){
         //Retrieve by column name
         String stopID  = rs.getString("stopID");
         String street1 = rs.getString("street1");
         String street2 = rs.getString("street2");
         String stopTime = rs.getString("stopTime");

         //Display values
         System.out.print("Stop ID: " + stopID);
         System.out.print(", Name: " + street1 + "/" +street2);
         System.out.println(", Time: " + stopTime);
      }

}

java.sql.SQLException: You have an error in your SQL syntax; check the manual that
corresponds to your MySQL server version for the right syntax to use near'
scheduled_stops.routeNumber = '051' AND scheduled_stops.direction = 'Northbound''
at line 1
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:2975)
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1600)
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:1695)
at com.mysql.jdbc.Connection.execSQL(Connection.java:3020)
at com.mysql.jdbc.Connection.execSQL(Connection.java:2949)
at com.mysql.jdbc.Statement.executeQuery(Statement.java:959)
at TransitManager.stopsOnRoute(TransitManager.java:460)
at TransitManager.main(TransitManager.java:104)

4 个答案:

答案 0 :(得分:0)

检查sql - 字符串是否存在第一行和第四行末尾的空格。

答案 1 :(得分:0)

您错过了stopIDWHERE之间的空格。

答案 2 :(得分:0)

在生成查询时,请记住,首先在sql shell或工具中运行它,然后在代码中使用适当的间距和字符串操作来实现。

 sql = "SELECT DISTINCT bus_stops.stopID, street1, street2 FROM bus_stops INNER JOIN scheduled_stops ON bus_stops.stopID = scheduled_stops.stopID"+
                  " WHERE scheduled_stops.routeNumber = '"+route+"' "+
                  " AND scheduled_stops.direction = '"+dir+"' "+
                  " AND scheduled_stops.stopTime > (SELECT stopTime FROM scheduled_stops WHERE scheduled_stops.stopID = '"+stop1+"' ORDER BY scheduled_stops.stopTime asc limit 1)"+ 
                  " AND scheduled_stops.stopTime < (SELECT stopTime FROM scheduled_stops WHERE scheduled_stops.stopID = '"+stop2+"' ORDER BY scheduled_stops.stopTime asc limit 1)";

答案 3 :(得分:0)

正确使用Whitspace。试试这个:

sql = "SELECT DISTINCT bus_stops.stopID, street1, street2 FROM bus_stops INNER JOIN scheduled_stops ON bus_stops.stopID = scheduled_stops.stopID "+
              "WHERE scheduled_stops.routeNumber = '"+route+"' "+
              "AND scheduled_stops.direction = '"+dir+"' "+
              "AND scheduled_stops.stopTime > (SELECT stopTime FROM scheduled_stops WHERE scheduled_stops.stopID = '"+stop1+"' ORDER BY scheduled_stops.stopTime asc limit 1) "+ 
              "AND scheduled_stops.stopTime < (SELECT stopTime FROM scheduled_stops WHERE scheduled_stops.stopID = '"+stop2+"' ORDER BY scheduled_stops.stopTime asc limit 1)";