-
查询单个对象
1、Query接口定义了uniqueResult方法,该方法强制返回结果只存在一个实例对象,而不再返回list集合形式的查询结果。
2、使用uniqueResult方法注意,通过where子句设置恰当的条件,保证符合查询条件的实例对象仅有一个,或者不存在,如果设置的查询条件不当,查询返回的实例对象多余一个,该方法就会抛出异常,终止运行。
案例:案例2:设置查询条件返回结果不唯一
查看全部 -
四则运算(+、-、*、/):对选择的属性做一些需要的运算。
1、HQL语句中也可以使用+、-、*、/四则运算。
2、四则运算可以在where子句和select子句中使用
案例:查询5件商品价格大于3000元的商品
查看全部 -
集合运算:HQL语句提供比较特殊的运算符,持久化映射中,存在一对多的映射配置,这里就可以使用集合运算符做相应的判定运算。
集合运算符:Hibernate框架会在hql解析过程中,解析成相应sql语句时
把empty——>exists把member of——>in运算。
1、is [not] empty判断集合类型属性[不]为空,不包含任何元素。
2、member of判断实例是否属于该集合
案例:查询订单明细不为空的有效订单
查看全部 -
逻辑运算:通过逻辑运算符,将逻辑表达式按照逻辑运算规则,形成一个新的逻辑表达式。
逻辑运算符:and(逻辑与)——如果逻辑表达式运算结果都为true则为true否则就为false、or(逻辑或)——如果逻辑表达式运算结果都为false则为false否则就为true、not(逻辑非)——对布尔运算结果取反。
案例:查询商品价格在100到5000元之间,并且类型为电脑类型
案例2:查询商品价格在100到5000之间或者是电脑类型
查看全部 -
字符串模式匹配:通过使用like关键字和通配符,对字符串类型的属性进行匹配运算(模糊查询)。
通配符:%、_。一个%形式可以匹配任意个字符,一个_形式匹配一个字符。
案例:查询顾客名字姓张的,并且有两个字的用户。
案例2:查询地址在北京的顾客信息(因为北京在地址中不固定,所以使用%通配符)
查看全部 -
范围运算:判断属性值是否在给定的条件范围之内。
1、[not] in (列表)————进行的范围运算,in关键字后为候选值列表,该候选值列表可以明确指出也可以是子查询,当属性值在候选列表中存在返回true,否则返回false。
2、[not] between 值1 and 值2————指定一个值的范围,只要属性值在这个范围内,该运算就返回true值,否则返回false。
案例:通过in关键字查询用户年龄20和40的用户
案例2:查询年龄在20到40之间的用户
查看全部 -
null值判断运算
案例:查询商品描述为null的商品
查看全部 -
比较运算:持久化类的属性与给定的查询条件进行比较。
1、比较运算符:=、<>、<、>、>=、<=。
2、null值判断————is [not] null,HQL中允许使用相等和不等进行null值判断,Hibernate框架会将x=null解析成x is null,x<>null解析成x is not null。
案例:查询价格大于400的商品
查看全部 -
本章内容简介
where子句:逻辑表达式,设置查询的条件,来限制返回的查询结果,实际应用情况中,通常要求不是返回持久化类的所有查询结果,尤其是数据量非常庞大时。
1、比较运算
2、范围运算
3、字符串模式匹配
4、逻辑运算
5、集合运算
6、在HQL中使用+-*/运算符
7、查询单个对象(uniqueResult方法)
查看全部 -
通过distinct返回不重复的查询结果
distinct关键字:去除查询结果中的重复元素。
当使用select语句以后,查询结果中的元素就不再保证是唯一的了,比如查询客户持久化类的时候,选择返回性别元素(select sex from Customer c),这时返回的结果就会发生重复,而在一个查询结果中,有两个相同的行,是没有意义的,这时就可以使用distinct关键字(select distinct sex from Customer c)消除查询结果中重复的元素。
查看全部 -
持久化类中无参构造方法的必要性:
当我们通过select语句完成自定义构造器查询,持久化类中是否还需要提供无参构造器呢?
答:持久化类中需要提供无参构造器。因为在HQL语句中,当指定了查询目标,并且指定了相应构造器后。Hibernate会调用指定的构造器,来进行对象的创建以及数据的封装,但是如果没指定相应的构造器,Hibernate会调用默认的构造器。
例如:from Seller s指定了查询目标,但没有指定相应构造器,Hibernate框架就会调用默认的构造器。
查看全部 -
select以自定义类型返回查询结果
1、持久化类中定义相应的构造器,构造器的参数就是我们要返回的属性信息。
2、select子句中调用定义的构造器来完成相应的查询,以自定义的类型返回查询结果。
案例:
查看全部 -
通过select子句指定返回结果类型为Map
定义:select子句中使用new map指定查询结果的数据类型为map,并需要注意在获取值时,Map中的key值为属性在select语句中的相应索引值(从0开始),并且类型为字符串类型。
查询结果与List完全一致的
Map的get方法除了可以使用属性在select语句中的索引位置来获取查询结果,还可以通过select子句中属性取别名来获取。
查看全部 -
通过select子句指定返回的查询结果为list类型。
定义:select子句中使用new list指定返回的查询结果
查看全部 -
使用select指定检索数据以Object[]方式返回查询结果(使用select子句进行查询,可以减少无用的数据传输量)
1、如果select子句中只是指定了查询的对象和属性,但是没有指定返回的数据类型,默认的查询结果以Object[]形式返回。
通过别名引用持久化类中属性的信息,返回指定属性的对象。
案例:通过select子句指定返回对象数组类型的查询结果,首先定义一个from子句(没有使用select子句),这样查询的是所有Seller持久化类的实例。
假设查询结果是供一个列表来使用的,列表只需要商家的名称、电话、地址、商家的星级,如果没有使用select子句,该查询的结果是商家所有字段的信息,包括了其它不需要的数据信息,这样就增加了无用的数据传输量,特别是表中的数据非常庞大时,会非常影响程序的性能,这时就需要使用select子句返回只需要的属性信息来提高程序的运行效率,这里可以通过别名来引用持久化类中的相应属性信息。
查询结果:
特殊情况注意:当使用select语句只查询对象的一个属性时,返回的数据类型就不是对象数组,而是对象Object。
select子句中不是一定使用别名来访问对象的属性,实际应用开发中,from子句中通常不会查询一个目标实体,如果多个实体目标中包含有同一个属性,使用别名可以区分,排除错误的产生。
查看全部
举报