在hibernate3下写hql语句,一定不要采用字符串拼接的方式,因为这样出来的结果往往是错误的和不可预料的,需要用?的方式来写.
比如find("from Article as t where t.keywork like '%中国%'");这样查询是得不到结果的,因为打出来的sql语句里,"中国"变成了"????",最好写成:
[code]
find("from Article as t where t.keywork like ?","%中国%");
[/code]
这样结果就正确了.
比如find("from Article as t where t.keywork like '%中国%'");这样查询是得不到结果的,因为打出来的sql语句里,"中国"变成了"????",最好写成:
[code]
find("from Article as t where t.keywork like ?","%中国%");
[/code]
这样结果就正确了.
本文介绍了在使用Hibernate 3时编写HQL语句的最佳实践。强调了避免使用字符串拼接来构造查询的重要性,并推荐使用预编译参数(?占位符)的方法,以确保查询的正确性和安全性。
1197

被折叠的 条评论
为什么被折叠?



