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