Rumah > pangkalan data > tutorial mysql > Gunakan MySQL dalam bahasa Go untuk mencapai perolehan data yang pantas

Gunakan MySQL dalam bahasa Go untuk mencapai perolehan data yang pantas

王林
Lepaskan: 2023-06-18 18:42:40
asal
1025 orang telah melayarinya

Dengan perkembangan Internet dan peningkatan jumlah data, pengambilan semula pantas telah menjadi satu keperluan untuk penyimpanan dan pengurusan data. Sebagai salah satu pangkalan data hubungan yang paling popular pada masa ini, MySQL mempunyai keupayaan pertanyaan yang kuat dan prestasi yang stabil. Artikel ini akan memperkenalkan cara menggunakan bahasa Go untuk mencapai perolehan semula data dengan pantas.

1. Asas pangkalan data MySQL

  1. Penciptaan dan penggunaan pangkalan data

Untuk mencipta pangkalan data baharu dalam MySQL, anda boleh menggunakan arahan berikut:

CREATE DATABASE database_name;
Salin selepas log masuk

Gunakan arahan berikut untuk memasuki pangkalan data yang ditentukan:

USE database_name;
Salin selepas log masuk
  1. Penciptaan dan penggunaan jadual

Gunakan arahan berikut untuk mencipta jadual:

CREATE TABLE table_name (
   column_name1 data_type1,
   column_name2 data_type2,
   ...
   column_nameN data_typeN
);
Salin selepas log masuk

Sebagai contoh, kita boleh mencipta jadual pengguna:

CREATE TABLE user (
   id INT PRIMARY KEY,
   name VARCHAR(20),
   age INT
);
Salin selepas log masuk

Untuk memasukkan data, gunakan arahan berikut:

INSERT INTO user (id, name, age) VALUES (1, 'Tom', 28);
Salin selepas log masuk

Untuk pertanyaan data, gunakan arahan berikut:

SELECT * FROM user WHERE age >= 25;
Salin selepas log masuk

2. Gunakan Pergi untuk menyambung ke MySQL

  1. Pasang pemacu pangkalan data

Mula-mula anda perlu memasang pemacu pangkalan data MySQL. Anda boleh menggunakan arahan berikut:

go get -u github.com/go-sql-driver/mysql
Salin selepas log masuk
  1. Mewujudkan sambungan

Gunakan kod berikut untuk mewujudkan sambungan ke pangkalan data MySQL:

import (
    "database/sql"
    _ "github.com/go-sql-driver/mysql"
)

func main() {
    db, err := sql.Open("mysql", "user:password@tcp(ip:port)/database_name")
    if err != nil {
        panic(err.Error())
    }
    defer db.Close()
}
Salin selepas log masuk

Anda perlu memasukkan pengguna, kata laluan, Gantikan ip, port dan nama_pangkalan data dengan nilai yang betul.

  1. Data pertanyaan

Gunakan kod berikut untuk menanyakan data:

rows, err := db.Query("SELECT * FROM user WHERE age >= ?", 25)
if err != nil {
    panic(err.Error())
}
defer rows.Close()
for rows.Next() {
    var id int
    var name string
    var age int
    err := rows.Scan(&id, &name, &age)
    if err != nil {
        panic(err.Error())
    }
    fmt.Println(id, name, age)
}
Salin selepas log masuk

Anda perlu menggantikan pernyataan SELECT dan parameter pertanyaan dengan nilai yang betul.

  1. Sisipkan data

Gunakan kod berikut untuk memasukkan data:

stmt, err := db.Prepare("INSERT INTO user (id, name, age) VALUES (?, ?, ?)")
if err != nil {
    panic(err.Error())
}
defer stmt.Close()
_, err = stmt.Exec(2, "Jerry", 30)
if err != nil {
    panic(err.Error())
}
Salin selepas log masuk

Penyataan INSERT dan parameter sisip perlu diganti dengan nilai yang betul.

3. Gunakan indeks untuk mempercepatkan pertanyaan

Indeks dalam MySQL ialah struktur data yang boleh mempercepatkan operasi pertanyaan pada lajur tertentu dalam jadual. Apabila menggunakan pangkalan data MySQL untuk pertanyaan data dalam bahasa Go, menggunakan indeks boleh meningkatkan kecekapan pertanyaan dengan ketara. Berikut ialah beberapa pengetahuan asas tentang indeks:

  1. Jenis indeks

Jenis indeks biasa dalam MySQL termasuk: indeks B-Tree, indeks cincang, indeks teks penuh, dsb. . Yang paling biasa digunakan ialah indeks B-Tree.

  1. Penciptaan indeks

Gunakan pernyataan berikut untuk mencipta indeks bagi lajur dalam jadual:

CREATE INDEX index_name ON table_name (column_name);
Salin selepas log masuk

Sebagai contoh, kita boleh mencipta indeks untuk lajur umur dalam jadual pengguna Cipta indeks:

CREATE INDEX age_index ON user (age);
Salin selepas log masuk
  1. Indeks menggunakan

Semasa membuat pertanyaan, anda boleh menggunakan pernyataan berikut untuk memaksa MySQL menggunakan indeks:

SELECT * FROM user USE INDEX (age_index) WHERE age >= 25;
Salin selepas log masuk

Dalam situasi sebenar, MySQL secara automatik akan memilih indeks yang paling sesuai untuk digunakan. Anda boleh menggunakan arahan berikut untuk melihat pelan pelaksanaan pertanyaan:

EXPLAIN SELECT * FROM user WHERE age >= 25;
Salin selepas log masuk

4. Ringkasan

Artikel ini memperkenalkan cara menggunakan bahasa Go untuk menyambung ke pangkalan data MySQL dan menggunakan indeks untuk mempercepatkan pertanyaan. Dalam aplikasi praktikal, menggunakan indeks yang sesuai dan mengoptimumkan pernyataan SQL boleh meningkatkan kecekapan pertanyaan dan prestasi pangkalan data dan mencapai perolehan data yang cepat.

Atas ialah kandungan terperinci Gunakan MySQL dalam bahasa Go untuk mencapai perolehan data yang pantas. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan