Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Menggunakan Operator Tugasan MySQL (:=) dalam Pertanyaan Asli Hibernate?

Bagaimana untuk Menggunakan Operator Tugasan MySQL (:=) dalam Pertanyaan Asli Hibernate?

Patricia Arquette
Lepaskan: 2024-11-03 00:36:29
asal
711 orang telah melayarinya

How to Use MySQL's Assignment Operator (:=) in Hibernate Native Queries?

Menggunakan Operator Tugasan MySQL (=:) dalam Pertanyaan Asli Hibernate

Apabila bekerja dengan pertanyaan asli MySQL dalam Hibernate, memanfaatkan pernyataan subpilihan selalunya diperlukan. Walau bagaimanapun, apabila menggunakan pengendali tugasan MySQL (:=) dalam pertanyaan ini, anda mungkin menghadapi pengecualian "Ruang tidak dibenarkan selepas awalan parameter ':'."

Isu ini berpunca daripada sekatan ruang putih Hibernate selepas awalan parameter. Walau bagaimanapun, penyelesaian wujud untuk kes khusus ini.

Betulkan untuk HHH-2697

Dalam versi Hibernate sebelum 4.1.3, tiada penyelesaian untuk isu ini. Walau bagaimanapun, pepijat HHH-2697 telah dibetulkan dalam keluaran kemudian.

Untuk Hibernate 4.1.3 dan ke atas, anda boleh melarikan diri dari operator tugasan dengan garis serong ke belakang (). Dengan berbuat demikian, anda boleh menggunakan pertanyaan yang diubah suai berikut:

<code class="sql">SELECT k.`news_master_id` AS id, @row \:= @row + 1 AS rownum 
FROM keyword_news_list k 
JOIN (SELECT @row \:= 0) r 
WHERE k.`keyword_news_id` = :kid
ORDER BY k.`news_master_id` ASC</code>
Salin selepas log masuk

Sintaks yang terlepas ini membolehkan anda menggunakan pengendali tugasan dalam pertanyaan asli anda tanpa menghadapi pengecualian yang disebutkan di atas.

Atas ialah kandungan terperinci Bagaimana untuk Menggunakan Operator Tugasan MySQL (:=) dalam Pertanyaan Asli Hibernate?. 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