将数据库从 MySQL 更改为 SQLite 后的 Java 项目错误

标签 java mysql sqlite netbeans jdbc

我正在学习Java 我已经使用 mysql 创建了简单的 (CRUD) java 程序,它工作正常

我想尝试使用相同的数据库切换到 SQLite(我已经将 mysql 数据库转换为 sqlite)

我正在使用这个 JDBC 驱动程序:https://bitbucket.org/xerial/sqlite-jdbc

但不知何故,netbeans无法完成运行我的程序(尽管之前没有错误) 我在输出栏上收到许多新错误:

java.lang.ClassNotFoundException: org.sqlite.JDBCException in thread "AWT-EventQueue-0" java.lang.NullPointerException
at tes.MainForm.Tampil(MainForm.java:46)
at tes.MainForm.<init>(MainForm.java:85)
at tes.MainForm$4.run(MainForm.java:329)
at java.awt.event.InvocationEvent.dispatch(InvocationEvent.java:251)
at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:733)
at java.awt.EventQueue.access$200(EventQueue.java:103)
at java.awt.EventQueue$3.run(EventQueue.java:694)
at java.awt.EventQueue$3.run(EventQueue.java:692)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:703)
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:242)
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:161)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:150)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:146)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:138)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:91)`

我的 DBConnection 类

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class DBConnection {   
Connection c = null;
Statement script;

public DBConnection(){
    try{
        Class.forName("org.sqlite.JDBC");
 //  Class.forName("com.mysql.jdbc.Driver");
   // c = DriverManager.getConnection("jdbc:ucanaccess://c:/asa.accdb");
 c = DriverManager.getConnection("jdbc:sqlite:C:/titit2.db");
   // c = DriverManager.getConnection("jdbc:mysql://localhost:3306/titit","root","root");
    script = c.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_UPDATABLE);
    System.out.println("Koneksi Sukses");
    }catch(  SQLException | ClassNotFoundException ex){
    System.err.print(ex);
    }
}
}

在我的 mainform 类中(第 23-46 行)

    private void Tampil(){
    try{
        int row = tabel.getRowCount();
        for(int i=0;i<row;i++){
            tabeldata.delete(0, row);
        }
        String sql;
        sql = "SELECT * from asu";
            ResultSet rs = c.script.executeQuery(sql);

        while(rs.next()){
            DataPegawai d = new DataPegawai();
            d.setNo(rs.getInt("no"));
            d.setNip(rs.getInt("nip"));
            d.setNama(rs.getString("nama"));
            d.setDivisi(rs.getString("divisi"));
            d.setLevel(rs.getInt("level"));
            tabeldata.add(d);
        }
    }catch(SQLException e){
        System.err.print(e);
    }
}

最佳答案

ClassNotFoundException 是您可以在运行时获得的异常。请参阅:http://docs.oracle.com/javase/7/docs/api/java/lang/ClassNotFoundException.html它说可能的原因:

Thrown when an application tries to load in a class through its string name using:

  • The forName method in class Class.
  • The findSystemClass method in class ClassLoader .
  • The loadClass method in class ClassLoader.

所以从我的角度来看,问题是您没有在 netbeans 中正确地将它添加到类路径中。

此外,您应该检查您使用的是稳定版本的驱动程序。我建议使用:sqlite-jdbc-3.7.2.jar

关于将数据库从 MySQL 更改为 SQLite 后的 Java 项目错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20065953/

相关文章:

java - foreach 函数在 Spark DataFrame 中不起作用

java - jvm运行垃圾收集时Kubernetes Pod内存使用率不下降

mysql super 奇怪的语法错误?

php - 从 php 文件运行命令时出现 SQL 错误

mysql - 在 Rails 中使用 Active Record 时如何指定 Ruby 正则表达式?

java - JDBC "database table is locked"错误

java - 将 SQLite 数据库复制到 Android 设备 C#

java - 如何在Webots中显示图表?

java - 如何让 Spring Boot 解析绑定(bind)到 ISO8601 格式的 LocalTime 的属性?

linq - 如何正确使用 Linq-to-SQLite?