当前位置: 代码迷 >> Java Web开发 >> hql查询中文问题
  详细解决方案

hql查询中文问题

热度:272   发布时间:2008-03-20 23:16:06.0
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]]
----------------解决方案--------------------------------------------------------
学习了
----------------解决方案--------------------------------------------------------
  相关解决方案