java - "UCanAccess: user lacks privilege or object not found"第二个连接

标签 java sql jdbc ucanaccess

现在我正在创建一个仪表板;我需要用来自 MS-Access 数据库的信息填充 JTable,为此我使用了这段代码。

try {
    con3 = Connectionz3.getConnection();//Connection Object 
    String dashboard2 = "Select * FROM [First_Entry]";
    pst3 = con.prepareStatement(dashboard2);
    rs3 = pst3.executeQuery();
    dtabla.setModel(DbUtils.resultSetToTableModel(rs3));

    PrinMenu.setVisible(false);
    Dashboard.setVisible(true);
}
catch (SQLException ex) {
        Logger.getLogger(Signin_Panel.class.getName()).log(Level.SEVERE, null, ex);
}

我得到了错误:

SEVERE: null
net.ucanaccess.jdbc.UcanaccessSQLException: UCAExc:::4.0.4 user lacks privilege or object not found: FIRST_ENTRY

奇怪的是我正在使用这段代码调用同一个数据库:

    con2 = Connectionz2.getConnection(); //Connection Object
    String query = "INSERT INTO [First_Entry](Entry_ID, Entrydate, Category_Call, VA_Creator, Name_Creator, VA_Agent, Name_Agent, Call_Date, Call_ID, q1,q2,q3,q4,q5,q6,q7,q8,q9,q10,q11,q12,q13,q14,q15,q16,q17,q18)" +
"values(?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)";

    PreparedStatement preparedStmt = con2.prepareStatement(query);
    preparedStmt.setInt(1, 0);
    preparedStmt.setString(2,cdate);
    preparedStmt.setString(3, Catcall);
    preparedStmt.setString(4, userva);
    preparedStmt.setString(5, fname+" "+lname);
    preparedStmt.setString(6,agentva);
    preparedStmt.setString(7,agentname);
    preparedStmt.setString(8, dotc);
    preparedStmt.setString(9, callid);
    preparedStmt.setInt(10, quest1);
    preparedStmt.setInt(11, quest2);
    preparedStmt.setInt(12, quest3);
    preparedStmt.setInt(13, quest4);
    preparedStmt.setInt(14, quest5);
    preparedStmt.setInt(15, quest6);
    preparedStmt.setInt(16, quest7);
    preparedStmt.setInt(17, quest8);
    preparedStmt.setInt(18, quest9);
    preparedStmt.setInt(19, quest10);
    preparedStmt.setInt(20,quest11);
    preparedStmt.setInt(21,quest12);
    preparedStmt.setInt(22,quest13);
    preparedStmt.setInt(23,quest14);
    preparedStmt.setInt(24,quest15);
    preparedStmt.setInt(25,quest16);
    preparedStmt.setInt(26,quest17);
    preparedStmt.setInt(27,quest18);

    preparedStmt.execute();

    con2.close();

这次成功了。

我不知道我是否以错误的方式调用了对象。我尝试更改位置、更改表的名称但不起作用。使用其他数据库填充JTable 没有任何问题,有什么建议吗?

最佳答案

看来您的问题出在这里:

con3 = Connectionz3.getConnection();//Connection Object 
String dashboard2 = "Select * FROM [First_Entry]";
pst3 = con.prepareStatement(dashboard2);

请注意您如何在上面的第一行定义 con3,然后在上面的第三行您使用 con 而不是 con3

所以将第三行改为:pst3 = con3.prepareStatement(dashboard2);

关于java - "UCanAccess: user lacks privilege or object not found"第二个连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52377872/

相关文章:

java - 库存元素使用的设计模式建议

mysql - 在同一地区找到至少 2 位顾客,他们至少喜欢一种用 SQL 出售的比萨饼

java - 如何在Java中创建一个具有可变列的数据库表?

java - 每个线程的新连接实例上的连接池 (JDBC)

sql - ORACLE:解释插入计划

java - 无法从 Spring 应用程序连接到 mssql 服务器

java - 如何在库存管理系统中应用依赖注入(inject)

java - 遗留项目结构 : intellij recognizes gradle subproject as module but doesn't recognize its source code

java - 找不到 spring schemalocation

sql - 当您执行 `SELECT *` 时,SQL Server 如何确定列的顺序?