Hibernate学习日记十(Query、Criteria、SQLQuery对象查询所有记录)

Query、Criteria、SQLQuery对象查询所有记录

·Query对象

1、使用query对象,不需要写sql语句,但是要写hql语句

(1)hql:Hibernate query language,hibernate提供查询语言,这个hql语句和普通sql语句很类似。

(2)hql和sql语句区别:

·使用sql操作表和表字段

·使用hql操作实体类和类属性

2、查询所有hql语句:

(1) from实体类的名称

			//创建Query对象,在createQuery里写hql语句
			Query query = session.createQuery("from User");

3、Query对象的使用

(1)通过Session.createQuery("from X")创建Qeury对象

(2)调用Query对象的方法得到结果

			//创建Query对象,在createQuery里写hql语句
			Query query = session.createQuery("from User");
			List <User>ls = query.list();

·Criteria对象

1、使用Criteria对象进行查询操作,不需要写查询语句,直接调用方法实现

2、实现过程

(1)通过Session.createCriteria(X)创建Criteria对象

(2)调用Criteria对象方法,得到结果

			//创建Query对象,在createQuery里写hql语句
			Criteria criteria = session.createCriteria(User.class);
			List <User>ls = criteria.list(); 

·SQLQuery对象

1、使用Hibernate也可以使用底层sql语句

2、实现过程

(1)创建SQLQuery对象

(2)调用SQLQuery对象的方法

			//创建SQLQuery对象,在createQuery里写hql语句
			SQLQuery sqlquery = session.createSQLQuery("selecT *  from user_login_next");
			//sqlquery.list()返回的List,默认里面的数据是以数组的形式存储
			//List <Object[]>ls = sqlquery.list(); 
			//当然,也可以使用sql.addEntity(x.class)把返回结果变成对象
			sqlquery.addEntity(User.class);
			List <User> ls = sqlquery.list();
//			for(Object[] arr : ls)
//			{	
//				for(int i = 0; i<arr.length;i++) {
//					System.out.println(arr[i]);
//				}
//				System.out.println(Arrays.toString(arr));
//			}
			for(User user : ls)
			{
				System.out.println(user);
			}

//创建Query对象,在createQuery里写hql语句Query query = session.createQuery("from User");List <User>ls = query.list();
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值