gpt4 book ai didi

java - PreparedStatement 错误

转载 作者:行者123 更新时间:2023-11-29 05:14:13 30 4
gpt4 key购买 nike

所以我有一个方法可以返回我得到的项目名称。但是对于第一个查询,它返回一个错误。我认为不应该在那里,因为它是正确的语法。这是代码:

void showInventory(String userId, MessageReceivedEvent event) throws HTTP429Exception, DiscordException, 
MissingPermissionsException{
sendMessage("test0",event);
String sql = "SELECT itemID FROM inventory WHERE playerID=?";
String sql2 = "SELECT Name FROM items WHERE ID=?";
java.sql.PreparedStatement state;
java.sql.PreparedStatement state2;

try {
state = Main.conn.prepareStatement(sql);
state2 = Main.conn.prepareStatement(sql2);
state.setString(1, userId);
ResultSet results = state.executeQuery(sql);
ResultSet resultname = null;
String invent = "";
sendMessage("test",event);

while(results.next()){
sendMessage("test1",event);
int result = results.getInt("itemID");
state2.setInt(1, result);
resultname = state2.executeQuery(sql2);

while(resultname.next()){
String name = resultname.getString("Name");
invent += (name + "\n");
}
}
sendMessage(invent, event);
} catch (SQLException e) {
e.printStackTrace();
}

}

这是错误:

com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: 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 '?' at line 1
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
at java.lang.reflect.Constructor.newInstance(Unknown Source)
at com.mysql.jdbc.Util.handleNewInstance(Util.java:404)
at com.mysql.jdbc.Util.getInstance(Util.java:387)
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:939)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3878)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3814)
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2478)
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2625)
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2547)
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2505)
at com.mysql.jdbc.StatementImpl.executeQuery(StatementImpl.java:1370)
at martacus.mart.bot.rpg.InventoryHandler.showInventory(InventoryHandler.java:48)
at martacus.mart.bot.rpg.InventoryHandler.OnMesageEvent(InventoryHandler.java:29)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at sx.blah.discord.handle.EventDispatcher.dispatch(EventDispatcher.java:104)
at sx.blah.discord.api.internal.DiscordWS.messageCreate(DiscordWS.java:323)
at sx.blah.discord.api.internal.DiscordWS.onMessage(DiscordWS.java:144)
at org.java_websocket.client.WebSocketClient.onWebsocketMessage(WebSocketClient.java:312)
at org.java_websocket.WebSocketImpl.decodeFrames(WebSocketImpl.java:368)
at org.java_websocket.WebSocketImpl.decode(WebSocketImpl.java:157)
at org.java_websocket.client.WebSocketClient.interruptableRun(WebSocketClient.java:230)
at org.java_websocket.client.WebSocketClient.run(WebSocketClient.java:188)
at java.lang.Thread.run(Unknown Source)

错误是关于名为 sql 的第一个字符串。调用于:

ResultSet results = state.executeQuery(sql);

最佳答案

通过调用 executeQuery(sql),您实际上是在 Statement 上调用一个方法 - 而不是在 PreparedStatement 上。因此,您丢弃已分配的参数值并执行占位符 ? 仍未解析的查询 - 因此您会收到该错误。

改变

 ResultSet results = state.executeQuery(sql);

 ResultSet results = state.executeQuery();

你应该没问题。

(当然

resultname = state2.executeQuery(sql2);

需要

resultname = state2.executeQuery();

还有)

关于java - PreparedStatement 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35408416/

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