mysql jdbc 绑定变量_JDBC MySql绑定变量语法错误在where子句中

我收到此错误:com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException:您的SQL语法有错误。检查与您的MySQL服务器版本相对应的手册,以获取在’?’附近使用的正确语法。在第1行

public static Person getDetails(int id) {

Connection conn = null;

PreparedStatement stmt = null;

Person newPerson = new Person();

try{

//STEP 2: Register JDBC driver

Class.forName("com.mysql.jdbc.Driver");

//STEP 3: Open a connection

System.out.println("Connecting to database...");

conn = DriverManager.getConnection(DB_URL,USER,PASS);

//STEP 4: Execute a query

System.out.println("Creating statement...");

String sql = "SELECT firstName, lastName, birthday FROM person WHERE id=?";

System.out.println("SQL Statement:\n\t" + stmt);

stmt = conn.prepareStatement(sql);

System.out.println("Prepared Statement before bind variables set:\n\t" + stmt.toString());

//Bind values into the parameters.

System.out.println("ID " + id);

stmt.setInt(1, id); // This would set id

System.out.println("Prepared Statement after bind variables set:\n\t" + stmt.toString());

// Let us select all the records and display them.

ResultSet rs = stmt.executeQuery(sql);

//STEP 5: Extract data from result set

while(rs.next()){

//Retrieve by column name

String firstName = rs.getString("firstName");

String lastName = rs.getString("lastName");

Date birthday = rs.getDate("birthday");

newPerson.setBirthday(birthday);

newPerson.setFirstName(firstName);

newPerson.setLastName(lastName);

newPerson.setId(id);

//Display values

System.out.print("ID: " + id);

System.out.print(", First: " + firstName);

System.out.println(", Last: " + lastName);

System.out.println(", Birthday: " + birthday);

}

//STEP 6: Clean-up environment

rs.close();

stmt.close();

conn.close();

}catch(SQLException se){

//Handle errors for JDBC

se.printStackTrace();

}catch(Exception e){

//Handle errors for Class.forName

e.printStackTrace();

}finally{

//finally block used to close resources

try{

if(stmt!=null)

stmt.close();

}catch(SQLException se2){

}// nothing we can do

try{

if(conn!=null)

conn.close();

}catch(SQLException se){

se.printStackTrace();

}//end finally try

}//end try

System.out.println("Goodbye!");

return newPerson;

}

我成功执行了不带where子句的查询。我看过许多示例,但我没有尝试解决此问题。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值