关闭

Hibernate HQL like 语句的用法

标签: hibernatestringquerytable数据库
27278人阅读 评论(2) 收藏 举报

String str = "中文字符串";
String hql = "FROM Table AS t WHERE t.field like '%" + str + "%'";

Query query = getSession().createQuery(hql);
query.list();

使用这种形式传入参数str, 会导致控制台输出:
FROM Table AS t WHERE t.field like '% ????%' 
之类的乱码, 从而在数据库找不到匹配记录.

据说这是hibernate3.0 like子句处理中文的一个问题, 3.1已得到修正。3.0版可以通过设置参数解决。改正如下:

String str = "中文字符串";
String hql = "FROM Table AS t WHERE t.field LIKE :param";
Query query = getSession().createQuery(hql);
query.setString("param", "%" + str + "%");
query.list();

一定要注意传进来的字符串变量是否现实乱码,如为乱码则永远查不到。

2
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:52158次
    • 积分:512
    • 等级:
    • 排名:千里之外
    • 原创:10篇
    • 转载:4篇
    • 译文:0篇
    • 评论:5条
    最新评论