Rumah > pembangunan bahagian belakang > Golang > Bagaimana untuk Menggabungkan Rentetan dan Nilai dalam Pertanyaan SQL dalam Go?

Bagaimana untuk Menggabungkan Rentetan dan Nilai dalam Pertanyaan SQL dalam Go?

Linda Hamilton
Lepaskan: 2024-10-26 17:38:03
asal
1029 orang telah melayarinya

How to Concatenate Strings and Values in SQL Queries in Go?

Penggabungan Pertanyaan SQL Setara dalam Go

Dalam Python, penyatuan rentetan dan nilai dalam pertanyaan SQL adalah mudah menggunakan operator %. Walau bagaimanapun, dalam Go, kaedah ini mungkin tidak berfungsi seperti yang diharapkan.

Untuk menyelesaikan isu ini, pengaturcara Go boleh menggunakan fungsi fmt.Sprintf. Contoh kod berikut menunjukkan cara yang betul untuk menggabungkan rentetan dan nilai:

<code class="go">query := fmt.Sprintf(`SELECT columnA FROM tableA WHERE columnB = %d AND columnB = %s`, SomeNumber, SomeString)</code>
Salin selepas log masuk

Kaedah ini memastikan bahawa nilai diformat dan dikendalikan dengan betul. Selain itu, adalah penting untuk mengambil perhatian potensi kelemahan serangan suntikan apabila membenamkan data yang disediakan pengguna dalam pertanyaan. Untuk mengurangkan risiko ini, pertimbangkan untuk menggunakan pendekatan berikut:

<code class="go">query := `SELECT column_name FROM table_name
    WHERE column1_name = %d AND column2_name = %d`

rows, err := db.Query(query, Val1, Val2)</code>
Salin selepas log masuk

Dengan menggunakan hujah berasingan untuk pertanyaan dan nilai, anda boleh menghalang input berniat jahat daripada mengubah struktur atau niat pertanyaan anda.

Atas ialah kandungan terperinci Bagaimana untuk Menggabungkan Rentetan dan Nilai dalam Pertanyaan SQL dalam Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan