Rumah >pangkalan data >tutorial mysql >Bagaimana untuk memanggil prosedur tersimpan MySQL dalam program Java

Bagaimana untuk memanggil prosedur tersimpan MySQL dalam program Java

PHPz
PHPzasal
2023-04-19 14:11:34990semak imbas

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.

  1. Memuatkan pemacu 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");
  1. Mewujudkan sambungan pangkalan data

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);
  1. Mencipta objek CallableStatement

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}".

  1. Tetapkan parameter dan laksanakan prosedur tersimpan

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()) {
    // 处理查询结果
}
  1. Tutup sambungan dan lepaskan sumber

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!

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