Dengan pembangunan berterusan aplikasi Internet, penyimpanan dan pemprosesan data telah menjadi bahagian teras setiap aplikasi. MySQL ialah sistem pengurusan pangkalan data hubungan sumber terbuka yang digunakan secara meluas dalam banyak perusahaan dan aplikasi web. Dalam MySQL, prosedur tersimpan ialah koleksi pernyataan SQL yang boleh diprogramkan yang boleh dipanggil beberapa kali dan digunakan semula. Artikel ini terutamanya memperkenalkan cara menggunakan Golang untuk menulis prosedur tersimpan MySQL.
1. Mengapa menggunakan prosedur tersimpan MySQL?
Prosedur tersimpan MySQL mempunyai kelebihan berikut semasa penggunaan:
2. Gunakan Golang untuk menulis prosedur tersimpan MySQL
Sebelum menggunakan Golang untuk menulis prosedur tersimpan MySQL, kita perlu memahami struktur asas dan sintaks prosedur tersimpan MySQL.
Prosedur tersimpan MySQL merangkumi empat bahagian: pengepala, pengisytiharan berubah, isi dan penamat prosedur. Antaranya, pengepala mengandungi nama dan pengisytiharan parameter prosedur tersimpan, dan badan mengandungi pernyataan SQL dan logik program tertentu.
Berikut ialah contoh prosedur tersimpan MySQL yang mudah:
CREATE PROCEDURE `hello_world`() BEGIN SELECT 'Hello, world!'; END
Sintaks prosedur tersimpan MySQL sedikit berbeza daripada biasa Pernyataan SQL terdapat perbezaan. Berikut ialah contoh sintaks prosedur tersimpan MySQL:
CREATE PROCEDURE procedure_name ([IN | OUT | INOUT] parameter_name data_type[(size)]) BEGIN -- procedure body END
Di Golang, kita boleh menggunakan MySQL yang disediakan oleh Go-MySQL -Pemandu Pemandu untuk menyambung ke pangkalan data MySQL dan melaksanakan prosedur tersimpan. Berikut ialah contoh Golang memanggil prosedur tersimpan MySQL:
package main import ( "database/sql" "fmt" _ "github.com/go-sql-driver/mysql" ) func main() { db, err := sql.Open("mysql", "root:password@tcp(127.0.0.1:3306)/test") if err != nil { panic(err.Error()) } defer db.Close() rows, err := db.Query("CALL hello_world()") if err != nil { panic(err.Error()) } defer rows.Close() var result string for rows.Next() { err := rows.Scan(&result) if err != nil { panic(err.Error()) } } fmt.Println(result) }
Dalam kod di atas, kami mula-mula menggunakan kaedah sql.Open() untuk menyambung ke pangkalan data MySQL. Kemudian, kami menggunakan kaedah db.Query() untuk melaksanakan prosedur tersimpan dan kaedah db.Scan() untuk mendapatkan hasil pertanyaan.
3. Ringkasan
Artikel ini memperkenalkan struktur asas dan sintaks prosedur tersimpan MySQL, dan menggunakan Golang untuk menulis contoh prosedur tersimpan MySQL yang ringkas. Apabila membangun dan menyelenggara aplikasi web, kami boleh menggunakan prosedur tersimpan MySQL untuk meningkatkan prestasi program, kebolehselenggaraan dan keselamatan data.
Atas ialah kandungan terperinci mysql stored procedure golang. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!