Hibernate高效查询,只查询部分/指定字段
来源:互联网 发布:海岛大亨mac汉化补丁 编辑:程序博客网 时间:2024/06/05 10:52
Hibernate 使用查询部分/指定字段,有三种字现方式:
第一种是使用高级查询DetachedCriteria实现,代碼如下:
- String alias = "user_"; //查詢時的table別名
- DetachedCriteria dc = DetachedCriteria.forClass(User.class,alias);
- ProjectionList pList = Projections.projectionList();
- pList.add(Projections.property(alias + "." + "id").as("id"));
- pList.add(Projections.property(alias + "." + "name").as("name"));
- pList.add(Projections.property(alias + "." + "age").as("age"));
- pList.add(Projections.property(alias + "." + "sex").as("sex"));
- dc.setProjection(pList);
- dc.setResultTransformer(Transformers.aliasToBean(User.class));
- resultList = memberService.findByDetached(dc).size();
String alias = "user_"; //查詢時的table別名DetachedCriteria dc = DetachedCriteria.forClass(User.class,alias);ProjectionList pList = Projections.projectionList();pList.add(Projections.property(alias + "." + "id").as("id"));pList.add(Projections.property(alias + "." + "name").as("name"));pList.add(Projections.property(alias + "." + "age").as("age"));pList.add(Projections.property(alias + "." + "sex").as("sex"));dc.setProjection(pList);dc.setResultTransformer(Transformers.aliasToBean(User.class));resultList = memberService.findByDetached(dc).size();
第二种方式是通过HQL语句new POJO()实现,方法如下:
- package com.domain;
- public class Link {
- private String id;
- private String name;
- private String url;
- private Integer index;
- public Link(){}
- //因为:String hql = "select new Link(id,name) from Link";
- //所以必须要有接受2个参数的构造函数
- public Link(String id,String name){
- this.id = id;
- this.name = name;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public String getUrl() {
- return url;
- }
- public void setUrl(String url) {
- this.url = url;
- }
- }
package com.domain;public class Link {private String id;private String name;private String url;private Integer index;public Link(){}//因为:String hql = "select new Link(id,name) from Link";//所以必须要有接受2个参数的构造函数public Link(String id,String name){this.id = id;this.name = name;}public String getName() {return name;}public void setName(String name) {this.name = name;}public String getUrl() {return url;}public void setUrl(String url) {this.url = url;}}
通過HQL语句查询
- String hql = "select new Link(id,name) from Link";
- Query query = session.createQuery(hql);
- //默认查询出来的list里存放的是一个Object对象,但是在这里list里存放的不再是默认的Object对象了,而是Link对象了
- List<Link> links = query.list();
- for(Link link : links){
- String id = link.getId();
- String name = link.getName();
- System.out.println(id + " : " + name);
- }
String hql = "select new Link(id,name) from Link";Query query = session.createQuery(hql);//默认查询出来的list里存放的是一个Object对象,但是在这里list里存放的不再是默认的Object对象了,而是Link对象了List<Link> links = query.list();for(Link link : links){String id = link.getId();String name = link.getName();System.out.println(id + " : " + name);}
第三种方式是通过HQL语句实现,类似SQL,方法如下:
- String hql = "select id,name from Link";
- Query query = session.createQuery(hql);
- //默认查询出来的list里存放的是一个Object数组,还需要转换成对应的javaBean。
- List<Object[]> links = query.list();
- for(Object[] link : links){
- String id = link[0];
- String name = link[1];
- System.out.println(id + " : " + name);
- }
- Hibernate高效查询,只查询部分/指定字段
- Hibernate高效查询,只查询部分/指定字段
- Hibernate高效查询,只查询部分/指定字段
- hibernate查询部分字段
- Hibernate - 查询部分字段
- hibernate查询部分字段
- hibernate 只查询某个字段
- hibernate查询指定字段示例
- Hibernate中用hql查询部分字段
- Hibernate中用hql查询部分字段
- Hibernate中用hql查询部分字段
- hibernate中getHibernateTemplate查询部分字段
- Hibernate中用hql查询部分字段
- Hibernate HQL 查询POJO部分字段
- Hibernate中用hql查询部分字段
- Hibernate使用Criteria查询部分字段
- 使用hibernate中getHibernateTemplate查询部分字段
- Hibernate查询部分字段并封装到指定类中(HQL)
- 用java正则表达式验证字符串(邮箱与网址)
- 判断一个整数中是否有重复数字(0~9),该数字不以0开头--------方法1
- cp & vfs & ubifs & ubi & mtd & nand driver 总结贴
- SVN常用命令
- C++ new & delete
- Hibernate高效查询,只查询部分/指定字段
- android权限大全
- Linux-0.00运行环境搭建
- 串口驱动卸载/加载与 GSM 模块电源控制
- 解析 H.264 NAL Unit 帧类型
- Python import细节探索
- asp内置对象
- spring入门(13)---JDK动态代理
- 深入浅出进程与线程的基本概念