hibernate--List ,Oblect,Mapd不同的返回属性

择-select子句,作用:指定只需要的查询信息,提高程序的运行效率
1.以Object[]形式返回选择的属性:
注意:hql的select查询语句中,如果指定了多个查询字段,则返回的是一个Object[]数组,然而如果只指定了一个查询字段,则返回的是一个Object对象。
String hql = "select s.name,s.tel from Seller s";
Query query = session.createQuery(hql);
List<Object[]> sellers = query.list();
for(Object[] objs:sellers){
System.out.println("name:"+objs[0]);
System.out.println("tel:"+objs[1]);
}(如果是单个查询字段的话就只需要把上面的Object[]中的[]去掉,打印输出时不需要指明下标)
2.以List形式返回选择的属性
String hql = "select new list(s.name,s.tel,s.address) from Seller s";
...
List<List>lists=query.getResultList();

3.以map形式返回选择的属性
注意:key为索引值,是字符串类型(map.get("0")),使用Map集合时考虑使用别名获取属性信息
String hql = "select new map(s.name,s.tel,s.address) from Seller s";

4.以自定义类型返回选择的属性
(1)持久化类中定义对应的构造器
(2)select子句中调用定义的构造器
注意:默认构造器是需要的,因为,在Hibernate没有指定的查询的放回集合时候,Hibernate会自动去找默认构造器,如果不存在,则会出现异常
String hql = "select new Seller(s.name,s.tel,s.address) from Seller s";

5.获取独特的结果-distinct关键字
distinct关键字 消除查询过程中重复的元素
String hql = "select distinct s.sex from Seller s";

以自定义类型返回数据

1.先创建自定义构造器

例如 public Sellers(String name,String address){

  this.name=name;

  this.address=address;

}
2.通过自定义类型返回查询结果
String hql="select new Seller(s.name,s.tel,s.address)from Seller s";
		
		Query query=session.createQuery(hql);
		
		List<Seller> lists=query.list();
		
		for (Seller seller : lists) {
			System.out.println("-----------------------------");
			System.out.println("name"+seller.getName());
			System.out.println("tel"+seller.getTel());
			System.out.println("address"+seller.getAddress());
			
		}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值