gpt4 book ai didi

JAVA写入Access数据库并检索和索引

转载 作者:行者123 更新时间:2023-11-29 09:08:40 26 4
gpt4 key购买 nike

我正在将数据从 Java 写入 Windows 32 位上的 Access 数据库。当我写一条记录时,我需要检索行 ID/主键,以便我可以 a) 如果我愿意,可以轻松更新记录,以及 b) 将其他数据交叉引用到该记录。

当在 C 中做类似的事情时,我可以制作一个可更新的游标,它允许我写入新记录并同时检索行 ID。使用 Java,看起来我应该能够做到这一点,但它会抛出以下代码的异常。

    con = openAccessDatabase();
String selectString = "SELECT ID, RunCount FROM SpeedTable";
try {
PreparedStatement selectStatement = con.prepareStatement(selectString,
ResultSet.TYPE_SCROLL_INSENSITIVE,
ResultSet.CONCUR_UPDATABLE);
ResultSet idResult = selectStatement.executeQuery();
int id;
for (int i = 0; i < nWrites; i++) {
idResult.moveToInsertRow();
idResult.updateObject(1, null); // this line makes no difference whatsoever !
idResult.updateInt(2, i);
idResult.insertRow(); // throws java.sql.SQLException: [Microsoft][ODBC Microsoft Access Driver]Error in row
id = idResult.getInt(1);
}
selectStatement.close();
} catch (SQLException e) {
e.printStackTrace();
}

我唯一能做的就是写一条新记录,然后运行不同的查询以取回行 ID ...

    String insertString = "INSERT INTO SpeedTable (RunCount) VALUES (?)";
String idString = "SELECT ID FROM SpeedTable ORDER BY ID DESC";
//
try {
ResultSet idResult = null;
PreparedStatement preparedStatement, idStatement;
preparedStatement = con.prepareStatement(insertString,
ResultSet.TYPE_FORWARD_ONLY,
ResultSet.CONCUR_READ_ONLY);
idStatement = con.prepareStatement(idString,
ResultSet.TYPE_FORWARD_ONLY,
ResultSet.CONCUR_READ_ONLY);

for (int i = 0; i < nWrites; i++) {
// write the data into the database
preparedStatement.setInt(1, i);
preparedStatement.execute();
// re-run the query to get the index back from the database.
idResult = idStatement.executeQuery();
idResult.next();
int lastIndex = idResult.getInt(1);
idResult.close();
}

这可行,但当表中有超过 10 条记录或 1000 条记录时,速度会变得不可思议。如果程序的两个部分同时开始写入(不太可能但并非不可能),也存在返回错误 ID 的风险。

我知道至少有一个建议是不使用 Java 或不使用 Access,但它们不是选项。它也是免费开源软件包的一部分,所以我不愿意为任何东西付费。编写我自己的 C JNI 接口(interface)来提供我的应用程序所需的基本功能更没有吸引力。

最佳答案

不确定这是否适用于 MS Access,但您可以尝试:

st.executeUpdate("INSERT INTO SpeedTable (RunCount) VALUES (1000)", Statement.RETURN_GENERATED_KEYS);
ResultSet rs = st.getGeneratedKeys();
rs.next();
long id = rs.getLong(1);

关于JAVA写入Access数据库并检索和索引,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13519604/

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