Menggunakan Pertanyaan Go MySQL dengan Pembolehubah SET
Anda sedang cuba menulis pertanyaan Go MySQL yang menetapkan pembolehubah dan menggunakannya dalam kompleks URUTAN MENGIKUT klausa. Pertanyaan berjalan dengan jayanya dalam konsol tetapi menghadapi ralat sintaks dalam Go.
Penyelesaian Kemungkinan
Malangnya, pakej pangkalan data/sql Go pada masa ini tidak menyokong tetapan pengguna MySQL- pembolehubah yang ditentukan. Oleh itu, pendekatan yang diterangkan dalam soalan tidak boleh dilaksanakan dengan had semasa pakej.
Pendekatan Alternatif
Penjanaan Pertanyaan Dinamik:
Satu alternatif ialah menjana klausa ORDER BY secara dinamik berdasarkan parameter input, menghapuskan keperluan untuk penggantian berubah.
<code class="go">func (d *DB) SelectByUserId(uid string, srt string, pg, lim int) ([]Inventory, error) { query := ` SELECT * FROM inventory WHERE user_id = ? ORDER BY ` + generateOrderBy(srt) + ` LIMIT ?,?; ` rows, err := d.Query( query, uid, pg*lim, lim, ) // ... (rest of the code remains the same) return result, nil } func generateOrderBy(srt string) string { order := "" switch srt { case "type,asc": order = "`type` ASC" case "type,desc": order = "`type` DESC" // ... (add other cases) } return order }</code>
Peluasan Parameter:
Sebagai alternatif, anda boleh mengembangkan ? ruang letak dalam rentetan pertanyaan untuk mengelakkan keperluan untuk pembolehubah. Pendekatan ini melibatkan membina rentetan yang menggantikan setiap ? dengan nilai parameter yang sepadan.
<code class="go">func (d *DB) SelectByUserId(uid string, srt string, pg, lim int) ([]Inventory, error) { query := fmt.Sprintf(` SELECT * FROM inventory WHERE user_id = '%s' ORDER BY CASE WHEN '%s' = 'type,asc' THEN `type` END, CASE WHEN '%s' = 'type,desc' THEN `type` END DESC, CASE WHEN '%s' = 'visible,asc' THEN visible END, CASE WHEN '%s' = 'visible,desc' THEN visible END DESC, CASE WHEN '%s' = 'create_date,asc' THEN create_date END, CASE WHEN '%s' = 'create_date,desc' THEN create_date END DESC, CASE WHEN '%s' = 'update_date,asc' THEN update_date END, CASE WHEN '%s' = 'update_date,desc' THEN update_date END DESC LIMIT %d,%d; `, uid, srt, srt, srt, srt, srt, srt, srt, srt, pg*lim, lim) rows, err := d.Query( query, ) // ... (rest of the code remains the same) return result, nil }</code>
Atas ialah kandungan terperinci Bagaimana untuk Menggunakan Pembolehubah SET dalam Pertanyaan Go MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!