使用原生SQL查询必须注意:程序必须选出所有的数据列才可被转换成持久化实体。
假设实体在映射时有一个<many-to-one../>的关联指向另外一个实体,则SQL查询中必须返回该<many-to-one../>映射的外键列,否则将导致抛出"column not found"异常。最简单的做法是,在SQL字符串中使用星(*)来表示返回所有列。
    在原生SQL语句中一样支持使用参数,这些参数即可使用问号参数(?),也可使用名字参数。

实战技巧:优化使用名字参数的形式,因为问号参数已经过时

示例1:名字参数
public void entityQuery(){
Seesion session=HibernateUtil.currentSession();
Transaction tx=session.beginTransaction();
String sqlString="Select * From strudent Where year =:year";
List l=session.createSQLQuery(sqlString)
.addEntity(Strudent.class)
.setParameter("year",2015)
.list();
tx.commit();
HibernateUtil.closeSession();
}
示例2:问号(?)参数
  public void listInstalledOrUn() {
try {
StringBuilder mysql = new StringBuilder();
mysql.append("SELECT t.*,c.*,p.* FROM (SELECT * FROM vrv_paw_reportlog WHERE TYPE IN(1001,1002) GROUP BY pcInfoId ORDER BY TIME DESC) "
           +"t INNER JOIN vrv_paw_cloudaccount c ON t.cloudAccountId=c.id INNER JOIN vrv_paw_pcinfo p ON t.pcInfoId=p.id WHERE 1=1 ");
List<Object> getParamList = new ArrayList<Object>();
createSQLWhereCondition(mysql, getParamList);
GridData<ReportLog> gridData = reportLogService.getPageView(mysql.toString(), getParamList, getPageNum(), getPageSize());
print(ActionUtil.jsonObj(gridData));
} catch (Exception e) {
log.info("获取列表失败");
e.printStackTrace();
}
}
   private void createSQLWhereCondition(StringBuilder mysql, List<Object> getParamList) {
if (StringUtils.isNotBlank(userName)) {
mysql.append(" AND c.name LIKE ? ");
getParamList.add("%" + userName + "%");
}
if (StringUtils.isNotBlank(ip)) {
mysql.append(" AND p.ip LIKE ? ");
getParamList.add("%" + ip + "%");
}
if (StringUtils.isNotBlank(mac)) {
mysql.append(" AND p.mac LIKE ? ");
getParamList.add("%" + mac + "%");
}
if (StringUtils.isNotBlank(version)) {
mysql.append(" AND VERSION LIKE ? ");
getParamList.add("%" + version + "%");
}
if (StringUtils.isNotBlank(type)) {
mysql.append(" AND TYPE=?");
getParamList.add(type);
}
if (StringUtils.isNotBlank(startTime)) {
mysql.append("AND TIME >=?");
getParamList.add(startTime);
}
if (StringUtils.isNotBlank(endTime)) {
mysql.append("AND TIME <=?");
getParamList.add(endTime);
}
}
方法getPageView:
  @SuppressWarnings("unchecked")
    @Override
    public GridData<ReportLog> getPageView(String sql, List<Object> getParamList, int pageNum, int pageSize) {
        List<Object> paramList = getParamList;         // 一、查询总记录数
        // a, 生成查询recordCount的Query对象,并设置参数
        Query countQuery = this.getSession().createSQLQuery(sql).addEntity(ReportLog.class);
        for (int i = 0; i < paramList.size(); i++) {
            countQuery.setParameter(i, paramList.get(i));
        }         // b, 查询出总记录数
        int recordCount = countQuery.list().size();         // 计算总页数
        int maxPageNum = (recordCount + pageSize - 1) / pageSize;
        if (pageNum > maxPageNum)
            pageNum = maxPageNum;         List<ReportLog> recordlist = null;
        if (recordCount > 0) {
            // ===============
            // 二、查询指定页的数据列表
            // a, 生成查询recordList的Query对象,并设置参数
            countQuery.setFirstResult((pageNum - 1) * pageSize);
            countQuery.setMaxResults(pageSize);             // b, 查询出当前页的数据列表
            recordlist = countQuery.list();
        }         return new GridData<ReportLog>(recordCount, recordlist);
    }
package com.vrv.paw.bean;

import java.io.Serializable;
import java.util.List; /**
* JavaBean:代表UI的一个网格*/
public class GridData<T> implements Serializable {
private static final long serialVersionUID = 1L; /** 总行数 **/
private int total;
/** 行数据 **/
private List<T> rows; public GridData() { } public GridData(int total, List<T> rows) {
this.total = total;
this.rows = rows;
} public int getTotal() {
return total;
}
public void setTotal(int total) {
this.total = total;
}
public List<T> getRows() {
return rows;
}
public void setRows(List<T> rows) {
this.rows = rows;
} }

不仅如此,如果在SQL语句中显示使用了多表连接,则SQL语句可以选出多个数据表的数据。Hibernate还支持将查询结果转换成多个实体。如果要将查询结果转换成多个实体,则SQL字符串中应为不同数据表指定不同别名,并调用addEntity(String alias,Class entityClass)方法将不同数据表转换程不同实体。

public void multiEntityQuery(){
Session session=HibernateUtil.currentSession();
Transaction tx=session.beginTransaction();
String sql="Select s.*,e.*,c.* From student s,enrolment e,course c Where s.id=e.id And e.code=c.code ";
List l=session.createSQLQuery(sql)
.addEntity("s",Student.class)
.addEntity("e",Enrolment.class)
.addEntity("c",Course.class)
.list();
tx.commit();
HibernateUtil.closeSession();
}

在Hibernate中使用原生SQL语句的更多相关文章

  1. Django中执行原生SQL语句【新编辑】

    参考我的个人博客 这部分迁移到了个人博客中:Django中执行原生SQL语句 这里需要补充一下,还有一个extra方法: ret = models.Student.objects.all().extr ...

  2. thinkPHP框架中执行原生SQL语句的方法

    这篇文章主要介绍了thinkPHP框架中执行原生SQL语句的方法,结合实例形式分析了thinkPHP中执行原生SQL语句的相关操作技巧,并简单分析了query与execute方法的使用区别,需要的朋友 ...

  3. django系列5.4--ORM中执行原生SQL语句, Python脚本中调用django环境

    ORM执行原生sql语句 在模型查询API不够用的情况下,我们还可以使用原始的SQL语句进行查询. Django 提供两种方法使用原始SQL进行查询:一种是使用raw()方法,进行原始SQL查询并返回 ...

  4. JPA或Hibernate中使用原生SQL实现分页查询、排序

    发生背景:前端展示的数据需要来自A表和D表拼接,A表和D表根据A表的主键进行关联,D表的非主键字段关联C表的主键,根据条件筛选出符合的数据,并且根据A表的主键关联B表的主键(多主键)的条件,过滤A表中 ...

  5. 在django中使用原生sql语句

    raw # row方法:(掺杂着原生sql和orm来执行的操作) res = CookBook.objects.raw('select id as nid from epos_cookbook whe ...

  6. 043:Django使用原生SQL语句操作数据库

    Django使用原生SQL语句操作数据库 Django配置连接数据库: 在操作数据库之前,首先先要连接数据库.这里我们以配置 MySQL 为例来讲解. Django 连接数据库,不需要单独的创建一个连 ...

  7. java:Hibernate框架3(使用Myeclipse逆向工程生成实体和配置信息,hql语句各种查询(使用hibernate执行原生SQL语句,占位符和命名参数,封装Vo查询多个属性,聚合函数,链接查询,命名查询),Criteria)

    1.使用Myeclipse逆向工程生成实体和配置信息: 步骤1:配置MyEclipse Database Explorer: 步骤2:为项目添加hibernate的依赖: 此处打开后,点击next进入 ...

  8. Django中使用mysql数据库并使用原生sql语句操作

    Django自身默认使用sqlite3这个轻量级的数据库,但是当我们开发网站时,sqlite3就没有mysql好,sqlite3适合一些手机上开发使用的数据库. 准备的软件mysql数据库,版本5.7 ...

  9. 关于No Dialect mapping for JDBC type :-9 hibernate执行原生sql语句问题

    转自博客http://blog.csdn.net/xd195666916/article/details/5419316,同时感谢博主 今天做了个用hibernate直接执行原生sql的查询,报错No ...

随机推荐

  1. DataGird 相关

    DataGird控件          DataGirdView 控件    DataGird类  他们之间是什么关系??????? DataGridView 控件是替换 DataGrid 控件的新控 ...

  2. SVN遇到的问题和解决方法(后期还会继续更新)

    1,smartsvn客户端(version客户端类似),一些.a文件无法识别,也就无法提交到svn! 解决办法如下: 在smartsvn客户端下面view->Ignored Files 勾选上就 ...

  3. Array类拓展方法

    var arr=[ {name:'one',sex:'girl',handsome:true}, {name:'two',sex:'girl',handsome:false}, {name:'thr' ...

  4. Redhat 7.4更新为Centos7的yum并安装docker-ce

    以下命令请在root下执行 #删除原有的yum rpm -qa|grep yum|xargs rpm -e --nodeps #install centos yum #wget http://mirr ...

  5. 金融 贷款类 App 审核被拒 4.3 1.2 2.1 4.2.2 问题总结

    辛辛苦苦搞了一两个月,开发测试修bug,一路艰辛,到了审核这最后一关,各位同仁,咬紧牙关!接下来是鄙人遇到过的被拒问题,望能帮到诸君! ******************************** ...

  6. [2012-12-18 14:59:31]AS3 常用正则表达式的总结-不用google了,我帮收集的很多了

    正则表达式是一种通用的标准,大部分计算机语言都支持正则表达式,包括as3,这里转摘出了一些常用的正则表达式语句,大家用到的时候就不用自己写了.红色字体为常用正则:下面这个类是我自己写的一个示例,想必大 ...

  7. 前端隐藏Ios及安卓滚动条

    1.方法不通用 // .scroll_list::-webkit-scrollbar { display:none } .scroll_list::-webkit-scrollbar-track { ...

  8. java并发编程与高并发解决方案

    下面是我对java并发编程与高并发解决方案的学习总结: 1.并发编程的基础 2.线程安全—可见性和有序性 3.线程安全—原子性 4.安全发布对象—单例模式 5.不可变对象 6.线程封闭 7.线程不安全 ...

  9. vultr VPS安装BBR

    1.安装 wget --no-check-certificate https://github.com/teddysun/across/raw/master/bbr.sh chmod +x bbr.s ...

  10. maven-surefire-plugin

    本文参考自:https://www.cnblogs.com/qyf404/p/5013694.html surefire是maven里执行测试用例(包括testNG,Junit,pojo)的插件,他能 ...