hql查询中文问题
hql查询中文问题public List getUserByName(final String userName)
{
try
{
return (List)this.getHibernateTemplate().execute(new HibernateCallback()
{
public Object doInHibernate(Session session) throws HibernateException, SQLException
{
Query query=session.createQuery("select count(*) from Users u where u.userName='11'");
List list= query.list();
System.out.println("size:"+list.get(0).toString());
return list;
}
});
}
catch(Exception e)
{
e.printStackTrace();
return new ArrayList();
}
}
数据库中有'11'记录.这样可以正确的显示出数据库中用户名为11的记录数.
但如果用户名为中文字段就查不出个数了.都显示0个。如下面的.
public List getUserByName(final String userName)
{
try
{
return (List)this.getHibernateTemplate().execute(new HibernateCallback()
{
public Object doInHibernate(Session session) throws HibernateException, SQLException
{
Query query=session.createQuery("select count(*) from Users u where u.userName='小东'");
List list= query.list();
System.out.println("size:"+list.get(0).toString());
return list;
}
});
}
catch(Exception e)
{
e.printStackTrace();
return new ArrayList();
}
}
数据库中有用户名为 '小东' 的记录.但总是显示查询结果为 0
为什么呢。数据是mysql 编码也是gb2312
搜索更多相关主题的帖子:
hql 中文 查询
----------------解决方案--------------------------------------------------------
'小东' 好亲切!!!!!!
----------------解决方案--------------------------------------------------------
在hibernate3当中使用antlr来解析hql的,估计是这方面对中文支持不够把
不过可以使用 使用下面的方式来解决
session.createQuery( "from table1 as t where t.name =: name ").setString( "name ", "搜索 ");
或者通过设置
<property name="hibernateProperties">
<prop key="hibernate.query.factory_class">
org.hibernate.hql.classic.ClassicQueryTranslatorFactory
</prop>
</props>
这是在spring中applicationContext.xml管理hibernate的时候的定义格式
[[it] 本帖最后由 lyd8935 于 2008-3-22 17:19 编辑 [/it]]
----------------解决方案--------------------------------------------------------
学习了
----------------解决方案--------------------------------------------------------