gpt4 book ai didi

java - 相同的查询在 MySQL 中工作,而不在 Java 客户端中工作

转载 作者:行者123 更新时间:2023-12-01 00:45:03 24 4
gpt4 key购买 nike

此查询在 MySQL Workbench 中运行时检索正确的值。

select person_id from person where person_name='John Adam';

但是当我通过 Java 代码运行它时,它在调用 executeQuery() 的行给出了异常。

SQLState: 42S22
Error Code: 1054
Message: Unknown column 'John Adam' in 'where clause'

我的代码是:

String inputname= JOptionPane.showInputDialog ( "Enter person's name:" ); 
String query= "select person_id from person where person_name= "+ inputname;

try {
stmt=con.createStatement();
ResultSet rs = stmt.executeQuery(query); // EXCEPTION AT THIS LINE
while (rs.next()){
rid= rs.getInt("person_id");
} // .....

您认为这可能是什么原因?

最佳答案

您需要在输入的两边加上引号

String query= "select person_id from person " + 
"where person_name= '"+ inputname + "'";

或者更好地使用Prepared Statements让转义自动为您执行程序。

关于java - 相同的查询在 MySQL 中工作,而不在 Java 客户端中工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23341087/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com