Rumah >pangkalan data >tutorial mysql >Bagaimana untuk memanggil prosedur tersimpan MySQL dalam program Java
Java ialah bahasa pengaturcaraan yang digunakan secara meluas Semasa membangunkan aplikasi web, selalunya perlu memanggil prosedur tersimpan MySQL untuk memproses data. Artikel ini akan memperkenalkan secara terperinci cara memanggil prosedur tersimpan MySQL dalam program Java.
1. Prosedur tersimpan MySQL
Prosedur tersimpan MySQL ialah koleksi kod SQL yang boleh merangkum pertanyaan SQL dan operasi data yang kompleks dan dipanggil apabila diperlukan. Prosedur tersimpan biasanya dilaksanakan lebih cepat daripada pernyataan SQL biasa.
Prosedur tersimpan MySQL boleh dibuat melalui klien MySQL atau alatan pengurusan, seperti MySQL Workbench. Kaedah mencipta prosedur tersimpan adalah serupa dengan menulis pernyataan SQL, tetapi anda perlu menggunakan perintah DELIMITER untuk menentukan penamat. Sebagai contoh, kod berikut mencipta prosedur tersimpan yang mudah:
DELIMITER // CREATE PROCEDURE GetProductList() BEGIN SELECT * FROM products; END // DELIMITER ;
Dalam kod di atas, DELIMITER menentukan aksara akhir sebagai "//", nama prosedur yang disimpan ialah GetProductList dan pernyataan SELECT dibaca daripada jadual "produk" ” untuk mendapatkan semua data.
2. Memanggil prosedur tersimpan MySQL dalam Java
Memanggil prosedur tersimpan MySQL adalah serupa dengan memanggil penyata SQL biasa dan memerlukan penggunaan Java JDBC API. Berikut ialah beberapa langkah asas untuk memanggil prosedur tersimpan MySQL menggunakan API JDBC.
Pemacu JDBC MySQL mesti dimuatkan sebelum menggunakan API JDBC dalam program Java. Anda boleh menggunakan kaedah Class.forName() untuk memuatkan pemandu, atau mendaftarkan pemandu melalui pakej balang pemacu JDBC. Contohnya:
Class.forName("com.mysql.cj.jdbc.Driver");
Mewujudkan sambungan pangkalan data memerlukan maklumat yang dinyatakan seperti alamat pelayan, nama pangkalan data, nama pengguna dan kata laluan. Sambungan pangkalan data boleh diwujudkan melalui kaedah getConnection() kelas DriverManager, contohnya:
String url = "jdbc:mysql://localhost:3306/mydb"; String user = "myuser"; String password = "mypassword"; Connection conn = DriverManager.getConnection(url, user, password);
Memanggil prosedur tersimpan MySQL memerlukan penggunaan objek CallableStatement, yang Boleh dibuat melalui kaedah Connection.prepareCall(). Contohnya:
String call = "{call GetProductList()}"; CallableStatement stmt = conn.prepareCall(call);
Perhatikan bahawa nama prosedur yang disimpan perlu disertakan dalam kurungan kerinting "{}" dan diawali dengan "{call}".
Sebelum memanggil prosedur tersimpan MySQL, anda perlu menetapkan parameter input dan output (jika ada). Parameter input ditetapkan menggunakan kaedah setXXX() dan parameter output didaftarkan menggunakan kaedah registerOutParameter() selepas memanggil prosedur. Untuk melaksanakan prosedur tersimpan gunakan kaedah CallableStatement.execute() atau CallableStatement.executeQuery(). Contohnya:
ResultSet rs = stmt.executeQuery(); while (rs.next()) { // 处理查询结果 }
Selepas menggunakan sambungan pangkalan data dan objek CallableStatement, anda harus menutup sambungan dan melepaskan sumber dalam masa untuk mengelakkan pembaziran sumber dan Kebocoran memori.
Contoh kod Java lengkap untuk memanggil prosedur tersimpan MySQL adalah seperti berikut:
import java.sql.*; public class CallStoredProcedure { public static void main(String[] args) { try { Class.forName("com.mysql.cj.jdbc.Driver"); String url = "jdbc:mysql://localhost:3306/mydb"; String user = "myuser"; String password = "mypassword"; Connection conn = DriverManager.getConnection(url, user, password); String call = "{call GetProductList()}"; CallableStatement stmt = conn.prepareCall(call); ResultSet rs = stmt.executeQuery(); while (rs.next()) { // 处理查询结果 } rs.close(); stmt.close(); conn.close(); } catch (Exception e) { e.printStackTrace(); } } }
3. Ringkasan
Melalui pengenalan artikel ini, pembaca boleh mempelajari cara untuk. memanggil prosedur tersimpan MySQL dalam program Java Langkah asas dan pertimbangan untuk prosedur tersimpan MySQL. Menggunakan prosedur tersimpan boleh meningkatkan kecekapan pelaksanaan SQL dan prestasi pemprosesan data, dan mempunyai nilai praktikal yang hebat untuk pembangunan aplikasi web yang kompleks.
Atas ialah kandungan terperinci Bagaimana untuk memanggil prosedur tersimpan MySQL dalam program Java. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!