java - Java:填写 PreparedStatement 的 SQLite 参数会导致错误
问题描述
我正在尝试使用SQLite-JDBC从 Java 中的 SQL 数据库读取数据,但是在向 a 填充参数PreparedStatement
时出现错误。代码的重要部分和错误如下。
Scanner scanner = new Scanner(System.in);
Connection db = DriverManager.getConnection("jdbc:sqlite:kurssit.db");
Statement s = db.createStatement();
PreparedStatement p;
p = db.prepareStatement("SELECT SUM(K.laajuus) "
+ "FROM Suoritukset S, Kurssit K "
+ "WHERE S.kurssi_id = K.id AND S.paivays LIKE '" + "?" + "%';");
p.setString(1, scanner.nextLine());
try {
ResultSet r = p.executeQuery();
System.out.println("Amount: " + r.getString(1));
} catch (SQLException e) {
System.out.println("Data not found.");
}
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: Index 0 out of bounds for length 0
at org.sqlite.core.CorePreparedStatement.batch(CorePreparedStatement.java:121)
at org.sqlite.jdbc3.JDBC3PreparedStatement.setString(JDBC3PreparedStatement.java:421)
at Main.main(Main.java:28)
C:\Users\user\AppData\Local\NetBeans\Cache\12.0\executor-snippets\run.xml:111: The following error occurred while executing this line:
C:\Users\user\AppData\Local\NetBeans\Cache\12.0\executor-snippets\run.xml:68: Java returned: 1
第 28 行,即错误所在的行,在这个缩短的代码版本中就是这样说的p.setString(1, scanner.nextLine());
。
//Imports
import java.sql.*;
import java.util.*;
提前谢谢了。
解决方案
sql 语句构造不正确。占位符不能在单引号内,因为如果是,那么它不被视为占位符,而只是一个字符串
。
它将被正确替换为之后的字符串。
改成这样:?
setString()
p = db.prepareStatement(
"SELECT SUM(K.laajuus) FROM Suoritukset S, Kurssit K WHERE S.kurssi_id = K.id AND S.paivays LIKE ? || '%';"
);
作为旁注,您应该使用正确的连接语法:
p = db.prepareStatement(
"SELECT SUM(K.laajuus) FROM Suoritukset S INNER JOIN Kurssit K ON S.kurssi_id = K.id WHERE S.paivays LIKE ? || '%';"
);
推荐阅读
- java - readInt 和 readLine 在 Java 中制作基本的加法机
- json - 使用 curl 使用 bashscript POST json
- mysql - MySQL如何将两个表(不同的字段)与两个语句组合起来
- c# - 使用单个源数据同时运行多个任务
- mysql - Mysql - 字符串A,B和B,A应该相同
- php - 如何更新 WooCommerce 订单商品数量
- javascript - 列出 Electron 中 ipcRenderer 的所有频道监听器
- python - 只有经过身份验证的用户才能访问媒体文件
- html - 在没有全屏浏览器的情况下在图像上显示全高(使用封面)
- spring - ¿ 如何在同一耳朵的不同战争之间共享安全和过滤器?