Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Menyelesaikan Ralat 'Tiada Pemacu Sesuai Ditemui' Semasa Menyambung ke MySQL Menggunakan JDBC?

Bagaimana untuk Menyelesaikan Ralat 'Tiada Pemacu Sesuai Ditemui' Semasa Menyambung ke MySQL Menggunakan JDBC?

Barbara Streisand
Barbara Streisandasal
2024-12-18 07:35:13370semak imbas

How to Resolve

Menyelesaikan Ralat "Tiada Pemacu Sesuai Ditemui" Semasa Menyambung ke MySQL

Ketidakupayaan untuk menyambung ke pangkalan data MySQL menggunakan JDBC selalunya ditunjukkan dalam salah satu daripada tiga mesej pengecualian:

  • java.sql.SQLException: Tiada pemandu yang sesuai ditemui untuk jdbc:mysql://database/table
  • java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
  • java.lang. ClassNotFoundException: com.mysql.cj.jdbc.Driver

Untuk menangani ralat ini, ikuti langkah komprehensif ini:

1. Pasang MySQL dan JDBC

  • Pasang pelayan MySQL.
  • Muat turun pemacu JDBC dan ekstrak fail JAR.

2. Tambahkan Pemacu JDBC ke Classpath

  • Dalam Eclipse atau Netbeans, tambahkan fail JAR sebagai Pustaka dalam Laluan Binaan.
  • Dalam baris arahan, nyatakan laluan ke fail JAR menggunakan - cp atau -classpath apabila melaksanakan aplikasi Java anda.

3. Cipta Pangkalan Data dan Pengguna dalam MySQL

  • Buat pangkalan data javabase dengan pengekodan UTF-8.
  • Buat pengguna bernama java dan berikan akses kepada pangkalan data.

4. Tentukan URL JDBC

Gunakan sintaks berikut untuk URL JDBC:

jdbc:mysql://hostname:port/databasename

Di mana:

  • nama hos: Localhost atau alamat IP untuk pelayan MySQL (lalai : 127.0.0.1)
  • port: Lalai: 3306
  • nama pangkalan data: Nama pangkalan data untuk disambungkan (cth., javabase)

5. Sambung ke MySQL Menggunakan Java

Buat kelas Java dengan kaedah utama dan wujudkan sambungan seperti berikut:

String url = "jdbc:mysql://localhost:3306/javabase";
String username = "java";
String password = "password";
try (Connection connection = DriverManager.getConnection(url, username, password)) {
    System.out.println("Database connected!");
} catch (SQLException e) {
    throw new IllegalStateException("Cannot connect the database!", e);
}

Sebagai alternatif, pemacu boleh dimuatkan secara manual sebelum membuat sambungan:

try {
    Class.forName("com.mysql.cj.jdbc.Driver");
    System.out.println("Driver loaded!");
} catch (ClassNotFoundException e) {
    throw new IllegalStateException("Cannot find the driver in the classpath!", e);
}

Menyelesaikan masalah

Jika menghadapi perkara berikut ralat:

  • SQLException: Tiada pemandu yang sesuai
Sama ada pemandu JDBC tiada dalam laluan kelas atau URL JDBC tidak betul.
  • Sambungan ditolak atau Kegagalan pautan komunikasi
Pelayan pangkalan data tidak dapat dicapai kerana IP/nama hos, port atau status pelayan yang salah. Semak tetapan konfigurasi rangkaian, pelayan atau tembok api.

Amalan Terbaik

  • Sentiasa tutup sambungan dengan segera menggunakan sumber cuba-dengan-untuk mengelakkan sumber pangkalan data yang meletihkan.
  • Elakkan menggunakan corak Singleton atau pembolehubah statik untuk sambungan pangkalan data kerana ini adalah sumber ralat biasa.

Atas ialah kandungan terperinci Bagaimana untuk Menyelesaikan Ralat 'Tiada Pemacu Sesuai Ditemui' Semasa Menyambung ke MySQL Menggunakan JDBC?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn