Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimana untuk Menggunakan Pembolehubah SET dalam Pertanyaan Go MySQL?

Bagaimana untuk Menggunakan Pembolehubah SET dalam Pertanyaan Go MySQL?

Patricia Arquette
Patricia Arquetteasal
2024-10-23 17:49:02396semak imbas

How to Use SET Variables in Go MySQL Queries?

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!

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