hibernate中使用sql语句总结

作为程序员最痛苦的莫过于修改别人的代码,尤其是架构不合理更是蛋疼,有谁家的hibrenate映射文件不维护关联关系的,关键是知道问题所在还不让动;所以遇到多表查询的时候不得不选择在hibernate中使用原生sql语句。

以下是自己开发过程中使用到的方法:

一、当单表查询时会遇到一些关键字(如:distinct)hibernate不支持,这时候使用原生sql语句, 直接上代码:


String sql="select distinct t1.id,t1.name from user t1";

List list=new ArrayList();
Session session=this.getSessionFactory().openSession();
//List list=this.getHibernateTemplate().find(hql);
Transaction tx=session.beginTransaction();
SQLQuery s=session.createSQLQuery(sql);
s.addScalar("id", Hibernate.STRING);
s.addScalar("name", Hibernate.STRING);
//在执行查询前必须执行addEntity()或是addScalar(),否则会报错。
//这里的addScalar方法是用于指定字段的数据类型,第一个参数是字段名称,第二个参数是数据类型
List list1=s.list();

tx.commit();
session.close();
//遍历结果集
if(list1!=null && list1.size()>0){
for(int i=0;i<list1.size();i++){
Object[] obj=(Object[])list1.get(i);
User te=new TExpInBook();

;
te.setId(id);
te.setName(obj[1].toString());
list.add(te);

}

}
return list;


二、当然最重要的还是多表查询,因为没有维护javabean的关联关系,所以在hibernate中不能使用left join、reght join等这些关键字
hibernate中使用原生sql进行多表查询跟上边的代码类似,但是不指定所需要查询的字段过不去(渣渣一枚,没有求知欲望,不知道为什么也没去找找原因),但是结果集字段好多按照上面的写法代码工作量又大,可读性又差。这时候有一个addJoin()方法可以挺方便的解决多表查询的问题,但是前提是javabean需要维护关联关系,这里给两个大神的博客地址,解释的清晰明白,不像我这么懒的朋友去看看吧!
http://langgufu.iteye.com/blog/1565397 hibernate
http://useky.blog.sohu.com/219680936.html hibernate
http://www.360doc.com/content/14/0530/14/16002580_382274995.shtml
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值