在Hibernate 中,當使用涉及MySQL 賦值運算子(:=)的查詢時,開發人員可能會遇到這樣的錯誤作為「參數前綴後不允許有空格:」。此問題的出現是由於 Hibernate 對賦值運算子處理的限制。
要解決此問題,受影響的使用者必須:
如問題報告HHH-2697,Hibernate 現在支援使用反斜線轉義賦值運算符。透過將原生查詢修改為:
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
該異常應該不再發生。
此外,更新到 Hibernate 版本 4.1.3 或更高版本將由於 HHH-2697 的修復已合併到這些版本中,因此解決了此問題。
透過採用其中任何一個解決方案,開發人員可以在 Hibernate 本機查詢中成功使用 MySQL 分配運算符,而不會遇到錯誤。
以上是如何在 Hibernate 本機查詢中使用 MySQL 賦值運算子?的詳細內容。更多資訊請關注PHP中文網其他相關文章!