问题描述:
向服务器向数据库发送select请求,返回用户名是xxx的数据。我遇到的问题是当我的用户名是数字的时候,可以进行查询并返回。当是英文字符和中文的时候,无法返回数据。
分析及解决过程
向数据库的查询过程代码如下:
public List<HeartRate> selectAllheart(String userName) {
List<HeartRate> heartrates = new ArrayList<>();Session session = this.getSession(true);Transaction tc = session.beginTransaction();//hql语句一List list = session.createQuery("From HeartRate where userName = "+userName+"order by heartId desc").list();//hql语句二//List list = session.createQuery("From HeartRate u where u.userName =:userName order by heartId desc").setString("userName",userName).list();for (Iterator iterator = list.iterator(); iterator.hasNext(); ) {
HeartRate heartrate = (HeartRate) iterator.next();heartrates.add(heartrate);}try {
tc.commit();} catch (Exception e) {
e.printStackTrace();}session.close();return heartrates;}}
使用session.createQuery创建查询语句
Hibernate中session.createQuery()与session.createSQLQuery()的区别
Query createQuery ( String queryString)
创建一个查询字符串中给定的HQL查询新的实例。
参数:HQL查询
返回值:Query查询
抛出异常:HibernateException
SQLQuery createSQLQuery ( String queryString)
创建一个新的查询字符串给定的SQL实例SQLQuery的。
参数:SQL查询
返回值:SQLQuery
抛出异常:HibernateException
简单来说,createQuery使用hql语句进行查询,以Hibernate生成的Bean为对象,并将对象装入List中返回。
createSQLQuery使用sql语句进行查询,是以对象数组形式返回。
使用hql语句一时,查询中文服务器返回错误
unexpected token: by near line 1, column 67 [From com.message.server.model.HeartRate where userName = qunorder by heartId desc]
根据这个报错,原因有如下两个可能:
-
1.在 hibernate 里面写sql执行时候使用了 session.createQuery(sql); 需要用 session.createSQLQuery(sql),或者是session.createQuery(hql) 而将 hql 语句写错;
-
2.在 hibernate 里面写hql执行是误把hql写成了sql,比如说:
select * from 表名
,hibernate框架操作数据库的核心就是:用操作数据对象代替操作表,给程序员的感觉是面向对象操作数据库。所以查询语句from后面接的不是表名称,而是javabean数据对象名
。
改成这样之后,发现英文用户名可以正常的返回结果。但是中文字符没有返回。
在服务器端控制台打印web端模拟Android端发送的请求,在服务器端打印获得的用户名发现是???
这个问题是由于编码格式的问题。应该选用UTF-8
。
在客户端发送的数据就是UTF-8
格式的数据。所以是在服务器端Java代码没有按照UTF-8
格式读取数据。
加入下面的代码将编码转换为 utf-8
//把ISO-8859-1编码的值变成utf-8
new String(value.getBytes("ISO-8859-1"), "utf-8");
再次测试可以正常打印用户名并返回数据
问题解决。同时还要注意数据库的默认编码格式是不是UTF-8,在applicationContext.xml 中设置
<!-- 数据库配置 --><bean id="dataSource"class="org.apache.commons.dbcp.BasicDataSource"><property name="driverClassName"value="com.mysql.jdbc.Driver"></property><property name="url"value="jdbc:mysql://**.**.**.***:8888/userdao?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true"><!-- 需设置characterEncoding=UTF-8 &autoReconnect=true--></property><property name="username" value="*****"></property><property name="password" value="******"></property><property name="maxActive" value="5" /><property name="maxIdle" value="40" /><property name="defaultAutoCommit" value="false" /><property name="timeBetweenEvictionRunsMillis" value="3600000" /><property name="minEvictableIdleTimeMillis" value="3600000" /></bean>