Hibernate 使用查询部分/指定字段,有几种字现方式:

第一种方式是通过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);
}

上述查询出来的数据还要手动封装成javaBean 比较低效

第二种方式是通过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;
  }
}

通过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);

第三种方式:

第二种方法,虽然已经可以自动封装,但还是存在缺陷,现实项目中,要查询出来的结果不一定是Link类里的属性能够满足的,我们可以根据根据需求来设计类。
我们要查询Link的 id name 和外键ID 这个情况下Link类无法满足需求  
id为Integer类型
name为String类型
foreignKeyId为integer类型
我们可以按照需求设计一个javaBean

定义一个javabean

public class Test {
private Integer id;
private String name;
private Integer foreignKeyId;
/**
* 无参构造
* @return
*/
public Test() {
super();
}
/**
* 有参构造
* @param id
* @param name
* @param foreignKeyId
*/
public Test(Integer id, String name, Integer foreignKeyId) {
super();
this.id = id;
this.name = name;
this.foreignKeyId = foreignKeyId;
}

public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getForeignKeyId() {
return foreignKeyId;
}
public void setForeignKeyId(Integer foreignKeyId) {
this.foreignKeyId = foreignKeyId;
}

}

然后将查询的结果放在这个javabean中

String hql = "select new Test(id,name,foreignKeyId) from Link";
Query query = session.createQuery(hql);
List<Object> links = query.list();
for(Test test : links){
System.out.println(test.toString());
}

 new Test(id,name,foreignKeyId) 中的类型必须和Test中构造函数的类型一致,名称可以不一致

第四种方式:setResultTransformer

SQL方式:

SQLQuery query = session.createSQLQuery(sql);
query.setResultTransformer(Transformers.aliasToBean(theClass));

HQL方式:

Query createQuery = session.createQuery(query)
.setResultTransformer(Transformers.aliasToBean(clazz));

demo1:

//返回一个map,KEY:为DB中名称一致(大小写一致)遍历list时就可以

Query query = session.createSQLQuery("select id,name from Tree t where pid in (select id from Tree) ")

.setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);

Map map = (Map)list.get[i];

map.get("id");map.get("name");来取值

按你的SQL语句select后的字段名来作为map的Key,但这个key必须与数据库中的字段名一模一样。

demo2:

query .createQuery("SELECT name as name, birthDate as birthDate  FROM CATS")
.setResultTransformer(Transformers.aliasToBean(CatDTO.class))

小注:查询select 中必须有as,as后面是CatDTO对应的class的属性名,必须的一致。

Hibernate查询部分字段并封装到指定类中的更多相关文章

  1. EF分组后把查询的字段具体映射到指定类里面的写法

    //先做基本查询 var querySql = from l in _logClinicDataOperationRepository.Table select new LogClinicDataOp ...

  2. hibernate查询部分字段转换成实体bean

    //hibernate查询部分字段转换成实体bean /** * 查询线路信息 */ @Override public List<Line> getSimpleLineListByTj(M ...

  3. MFC--串口编程---WIN API的方式将串扣操作封装在线程类中

    串口采集数据 本文档介绍的是如何获取串口原始数据并将原始数据解析成可处理或可展示的数据. 一.串口采集有很多方式: 1).MFC有一个专门的控件,直接编程采集,一个控件只能采集一个串口,而且串口名字比 ...

  4. java---解析XML文件,通过反射动态将XML内容封装到一个类中

    本博客讲的XML解析,使用的是dom4j. 首先建立一个maven项目,在dom.xml中引入相应的dom4j的版本.作者下载的是热度很高的1.6.1版本.maven的使用在这里不做详细讲解. 引入成 ...

  5. mysql与hibernate选择某个字段的最大值,比如表中的最大id

    hibernate public int getMaxId(Session session) { String hql = "SELECT MAX(id) FROM ArticleModel ...

  6. mysql如何查询一个字段在哪几张表中

    SELECT TABLE_SCHEMA,TABLE_NAME FROM information_schema.`COLUMNS` WHERE COLUMN_NAME = 'xxx' ; xxx替换成需 ...

  7. resultMap自定义映射---8.3.1. 解决列名(表中的字段名称)和实体类中的属性名不一致

    1.1.1.1.      步骤一:将驼峰匹配注释掉 --------------测试完成后仍然 回来开启  其他地方可能用到 一旦注释掉驼峰匹配,那么再通过queryUserById查询的结果中,用 ...

  8. java中使用反射做一个工具类,来为指定类中的成员变量进行赋值操作,使用与多个类对象的成员变量的赋值。

    //------------------------------------------------我是代码的分割线 // 首选是一个工具类,在该工具类里面,定义了一个方法,public void s ...

  9. 将Java连接数据库操作封装到MySQL类中

    public class MySQL { final String JDBC_DRIVER = "com.mysql.cj.jdbc.Driver"; final String D ...

随机推荐

  1. 转自CSDN-详述 Java 中的别名现象

    在任何编程语言中,赋值操作都是最常见的操作之一,Java 自然也不例外.赋值时,使用赋值操作符=,它的意思是:“将等号右边的值(右值),复制给左边的值(左值)”.右值可以是任何常数.变量或者表达式(只 ...

  2. ubuntu 16.04 编译安装 amule (开启GUI)

    安装依赖 $ -dev libgeoip-dev zlib1g-dev libupnp-dev libboost-all-dev libwxbase3.-dev libwxgtk3.-dev buil ...

  3. 记一次Vue中v-model和v-bind区别

    由于v-model 只是语法糖, <input v-model="message"> 与下面的两行代码是一致的: <input v-bind:value=&quo ...

  4. Django的forms表单组件批量设置字段样式

    from django import forms from . import models class UserInfoModelForms(forms.ModelForm): class Meta: ...

  5. 利用Python进行数据处理1——学会使用NumPy

    一.学会使用ndarray 1.1什么是ndarray? ndarray是NumPy中的一种多维数组对象,他可以是一维的.二维的.甚至更多维次.当然创建更多维次的数组并不是他的优点所在,他的优点在于它 ...

  6. 当进行服务端渲染的时间,某些npm包可能会调用document,window这些对象而导致报错

    1.在didmount里面使用require引入 require.ensure([], (require) => { this.setState({ picker: require('./Pic ...

  7. Arch Linux 硬盘引导-联网安装

    Arch Linux 硬盘引导-联网安装 ============https://www.archlinux.org/https://wiki.archlinux.org/https://wiki.a ...

  8. 关于nginx安装、iptables设置和查看端口指令netstat/ss

    实验1: Nginx介绍 Nginx("engine x")是一款是由俄罗斯的程序设计师Igor Sysoev所开发高性能的 Web和 反向代理 服务器,也是一个 IMAP/POP ...

  9. python3+qqBot+图灵机器人实现qq聊天机器人

    原理: 通过Python3的qqBot开源库,基于腾讯的smartQQ协议登录个人QQ,实现监控.收集QQ消息,进而通过图灵机器人API接入方式实现自动聊天. 零.前期准备: 1.Python3 2. ...

  10. 尝试document.getElementById()失败

    document.getElementById() document.getElementsByTagName() 电脑重启,新建文件后尝试成功