查看: 254|回复: 0
打印 上一主题 下一主题

hibernate — HQL语句总结

[复制链接]

9万

主题

9万

帖子

28万

积分

管理员

管理员

Rank: 9Rank: 9Rank: 9

积分
289121
跳转到指定楼层
楼主
发表于 2017-10-2 07:35:33 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

1. 查询全部映照工具一切字段
  • //间接from查询出来的是一个映照工具,即:查询全部映照工具一切字段   
  •         String hql = "from Users";
  •         Query query = session.createQuery(hql);
  •         List[U] users = query.list();
  •         for(Users user : users){
  •             System.out.println(user.getName() + " : " + user.getPasswd() + " : " + user.getId());
  •         }


  • 输出成果为:  
    name1 : password1 : 1
    name2 : password2 : 2
    name3 : password3 : 3
    2.查询字段
  • //查询其中几个字段   
  •         String hql = " select name,passwd from Users";
  •         Query query = session.createQuery(hql);
  •         //默许查询出来的list里寄存的是一个Object数组   
  •         List list = query.list();
  •         for(Object[] object : list){
  •             String name = (String)object[0];
  •             String passwd = (String)object[1];
  •             System.out.println(name + " : " + passwd);
  •         }

    输出成果为:  
    name1 : password1
    name2 : password2
    name3 : password3
    3.点窜默许查询成果(query.list())不以Object[]数组形式返回,以List形式返回
  • //查询其中几个字段,增加new list(),留意list里的l是小写的。也不需要导入包,这样经过query.list()出来的list里寄存的不再是默许的Object数组了,而是List调集了  
  •          String hql = " select new list(name,passwd) from Users";
  •         Query query = session.createQuery(hql);
  •         //默许查询出来的list里寄存的是一个Object数组,可是在这里list里寄存的不再是默许的Object数组了,而是List调集了   
  •         List list = query.list();
  •         for(List user : list){
  •             String name = (String)user.get(0);
  •             String passwd = (String)user.get(1);
  •             System.out.println(name + " : " + passwd);
  •         }

    输出成果为:
    name1 : password1
    name2 : password2
    name3 : password3
    4.点窜默许查询成果(query.list())不以Object[]数组形式返回,以Map形式返回
  • //查询其中几个字段,增加new map(),留意map里的m是小写的。也不需要导入包,这样经过query.list()出来的list里寄存的不再是默许的Object数组了,而是map调集了   
  •         String hql = " select new map(name,passwd) from Users";
  •         Query query = session.createQuery(hql);
  •         //默许查询出来的list里寄存的是一个Object数组,可是在这里list里寄存的不再是默许的Object数组了,而是Map调集了   
  •         List list = query.list();
  •         for(Map user : list){
  •             //一笔记录里一切的字段值都是map里的一个元素,key是字符串0,1,2,3....,value是字段值   
  •             //假如将hql改成:String hql = " select new map(name as username,passwd as password) from Users";,那末key将不是字符串0,1,2...了,而是"username","password"了   
  •             String name = (String)user.get("0");//get("0");是get(key),留意:0,1,2...是字符串,而不是整形   
  •             String passwd = (String)user.get("1");
  •             System.out.println(name + " : " + passwd);
  •         }

    输出成果为:
    name1 : password1
    name2 : password2
    name3 : password3
    5.点窜默许查询成果(query.list())不以Object[]数组形式返回,以自界说范例返回
    6.条件查询
  • //条件查询,参数索引值从0起头,索引位置。经过setString,setParameter设备参数   
  •         String hql = "from Users where name=? and passwd=?";
  •         Query query = session.createQuery(hql);
  •         //第1种方式   
  • //      query.setString(0, "name1");   
  • //      query.setString(1, "password1");   
  •         //第2种方式   
  •         query.setParameter(0, "name1",Hibernate.STRING);
  •         query.setParameter(1, "password1",Hibernate.STRING);
  •         List[U] list = query.list();
  •         for(Users users : list){
  •             System.out.println(users.getId());
  •         }

  • //条件查询,自界说索引名(参数名):username,:password.经过setString,setParameter设备参数   
  •         String hql = "from Users where name=:username and passwd=:password";
  •         Query query = session.createQuery(hql);
  •         //第1种方式   
  • //      query.setString("username", "name1");   
  • //      query.setString("password", "password1");   
  •         //第2种方式,第3个参数肯定范例   
  •         query.setParameter("username", "name1",Hibernate.STRING);
  •         query.setParameter("password", "password1",Hibernate.STRING);
  •         List[U] list = query.list();
  •         for(Users users : list){
  •             System.out.println(users.getId());
  •         }

  • //条件查询,经过setProperties设备参数   
  •         String hql = "from Users where name=:username and passwd=:password";
  •         Query query = session.createQuery(hql);
  •         //MyUser类的2个属性必须和:username和:password对应   
  •         MyUser myUser = new MyUser("name1","password1");
  •         query.setProperties(myUser);
  •         List[U] list = query.list();
  •         for(Users users : list){
  •             System.out.println(users.getId());
  •         }

    7.update 数据
    履行SQL语句(为什么要用SQL语句,我想是为了履行某些复杂的SQL语句吧)
  • String sql="update Table set field = 'test'"
  • Session session = HibernateSessionFactory.getSession();
  • session.createSQLQuery(sql).executeUpdate();
  • ts.commit();

    履行HQL语句
  • String hql="update Table set field = 'test'"
  • Session session = HiberanteSessionFactory.getSession();
  • Transaction ts = session.beginTransaction();
  • Query query = session.createQuery(hql);
  • query.executeUpdate();
  • ts.commit();

  • 回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|Archiver|手机版|IT视频教程资源网

    GMT+8, 2025-1-3 14:57 , Processed in 1.787857 second(s), 22 queries .

    快速回复 返回顶部 返回列表

    客服
    热线

    微信
    7*24小时微信 客服服务

    扫码添
    加微信

    添加客服微信获取更多

    关注
    公众号

    关注微信公众号