gpt4 book ai didi

java - 尝试更新 Access 数据库时出现 NonWritableChannelException

转载 作者:行者123 更新时间:2023-11-30 08:33:33 27 4
gpt4 key购买 nike

第一次在一个项目中使用 UCanAccess,我在向我的一个数据库表(在 Microsoft Access 中)插入一行时遇到了很多麻烦。

我的代码是有道理的,但是一旦我执行,我每次都会得到同样的错误,即使 NetBeans 能够连接到我的数据库。

 
package Vegan;<p></p>

<pre><code>import java.sql.Connection;
import java.sql.DriverManager;


public class connectionString {

static Connection connection = null;

public static Connection getConnection()
{
try
{
connection = DriverManager.getConnection("jdbc:ucanaccess://C://MyDatabase1.accdb");
System.out.println("---connection succesful---");
}

catch (Exception ex)
{
System.out.println("Connection Unsuccesful");
}

return connection;
}
</code></pre>

<p></p>


package Vegan;<p></p>

<pre><code>import java.sql.*;
import java.util.ArrayList;
import java.util.List;
import java.util.logging.Level;
import java.util.logging.Logger;


public class DB {


private static ResultSet rs = null;
private static PreparedStatement ps = null;
private static Connection connection = null;

public DB() {
connection = connectionString.getConnection();
}


public void AddTest() {
try {

String sql = "INSERT INTO CategoryTbl(CategoryName) VALUES (?)";
ps = connection.prepareStatement(sql);

ps.setString(1, "Flours");
ps.executeUpdate();
System.out.println("Inserted");
} catch (Exception ex) {
System.out.println(ex.getLocalizedMessage().toString());
}
</code></pre>

<p>}
</p>

之后,当我执行 AddTest() 方法时,我得到以下系统输出:


run:
---connection succesful---
java.nio.channels.NonWritableChannelException
at sun.nio.ch.FileChannelImpl.write(FileChannelImpl.java:724)
at com.healthmarketscience.jackcess.impl.PageChannel.writePage(PageChannel.java:297)
UCAExc:::3.0.6 null
at com.healthmarketscience.jackcess.impl.PageChannel.writePage(PageChannel.java:234)
at com.healthmarketscience.jackcess.impl.TableImpl.writeDataPage(TableImpl.java:1375)
at com.healthmarketscience.jackcess.impl.TableImpl.addRows(TableImpl.java:1624)
at com.healthmarketscience.jackcess.impl.TableImpl.addRow(TableImpl.java:1462)
at net.ucanaccess.converters.UcanaccessTable.addRow(UcanaccessTable.java:44)
at net.ucanaccess.commands.InsertCommand.insertRow(InsertCommand.java:101)
at net.ucanaccess.commands.InsertCommand.persist(InsertCommand.java:148)
at net.ucanaccess.jdbc.UcanaccessConnection.flushIO(UcanaccessConnection.java:315)
at net.ucanaccess.jdbc.UcanaccessConnection.commit(UcanaccessConnection.java:205)
at net.ucanaccess.jdbc.AbstractExecute.executeBase(AbstractExecute.java:161)
at net.ucanaccess.jdbc.ExecuteUpdate.execute(ExecuteUpdate.java:50)
at net.ucanaccess.jdbc.UcanaccessPreparedStatement.executeUpdate(UcanaccessPreparedStatement.java:253)
at Vegan.DB.AddTest(DB.java:91)
at Vegan.TestDB.main(TestDB.java:17)
BUILD SUCCESSFUL (total time: 1 second)

当我再次检查 Access 时,没有对数据库进行任何更改。是什么原因造成的,错误消息是什么意思?谢谢

最佳答案

“java.nio.channels.NonWritableChannelException”表示数据库文件无法更新。在您的情况下,这是因为数据库文件位于 Windows 系统驱动器 (C:\) 的根文件夹中,而凡人对该文件夹的权限有限。

解决方案:将数据库文件移动到您具有完全写入权限的文件夹。

关于java - 尝试更新 Access 数据库时出现 NonWritableChannelException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39400354/

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