Rumah >pembangunan bahagian belakang >Golang >Bagaimana Menggunakan Pertanyaan LIKE dengan Nilai Parameter dengan betul dalam Pemacu PostgreSQL pq Go?

Bagaimana Menggunakan Pertanyaan LIKE dengan Nilai Parameter dengan betul dalam Pemacu PostgreSQL pq Go?

Barbara Streisand
Barbara Streisandasal
2024-12-07 11:45:16622semak imbas

How to Properly Use LIKE Queries with Parameterized Values in Go's pq PostgreSQL Driver?

Go postgresql LIKE Query dengan Nilai Parameter

Dalam Go, apabila bekerja dengan pemacu pq untuk PostgreSQL, adalah perlu untuk memastikan pemformatan yang betul pertanyaan yang melibatkan klausa LIKE. Isu biasa yang dihadapi semasa cuba menggunakan operator LIKE ialah ralat sintaks yang menunjukkan aksara tidak sah pada atau berhampiran simbol peratusan ("%").

Untuk menyelesaikan isu ini, corak LIKE mesti disertakan dalam satu. petikan apabila diluluskan sebagai parameter. Ini memastikan bahawa aksara khas ditafsirkan dengan betul oleh pangkalan data PostgreSQL. Pertanyaan yang dikemas kini di bawah termasuk pembetulan ini:

query := `SELECT p.id, p.name, p.description, p.price, p.image, p.rate
    FROM products AS p
    WHERE LOWER(p.name) LIKE '%' ||  || '%'
    ORDER BY p.rate DESC;`

Dalam pertanyaan ini, corak LIKE disertakan dalam petikan tunggal dan digabungkan dengan parameter $1 menggunakan || pengendali. Ini memastikan bahawa pangkalan data mentafsir corak sebagai rentetan dan bukan sebagai aksara khas.

Dengan pengubahsuaian ini, pertanyaan harus dilaksanakan dengan jayanya dalam PostgreSQL. Ia akan mencari produk yang namanya sepadan dengan corak yang ditentukan dan menyusun keputusan dalam tertib menurun ratingnya.

Atas ialah kandungan terperinci Bagaimana Menggunakan Pertanyaan LIKE dengan Nilai Parameter dengan betul dalam Pemacu PostgreSQL pq Go?. 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