简介 目录 评价 推荐
  • Lair 2019-10-29

    集合运算介绍

    截图
    0赞 · 0采集
  • 大鹏111 2019-06-17

    课程总结

    HQL需要注意的知识点和编写HQL时要注意的问题

    1、HQL语句形式(只有了解了HQL语句形式,才会清楚HQL各个子句在HQL中的位置,对HQL语句的编写,特别是比较复杂的HQL语句的编写,很有帮助)

    https://img.mukewang.com/5d077ba70001bd6a10950231.jpg

    2、HQL语句大小写敏感,特别是持久化类及其属性的大小写(查询的主题是持久化类及其属性,但HQL关键字大小写不敏感,但为了程序的美观、可读性、习惯小写)。

    3、别名的使用(方便HQL语句的编写,注意别名的习惯命名惯例,单字母的别名要与持久化类有一定的关联,这样在其他子句使用别名的时候,可以最大程度的避免误用,方便程序的修改和维护)

    https://img3.mukewang.com/5d077c9e0001d0a903800345.jpg

    4、select子句使用自定义类返回选择属性,持久化类构造器处理。

    注意:当自定义了构造器之后,一定要在持久化类中增加默认构造器,保证在其他查询情况下,Hibernate框架使用默认构造器时,创建实例对象不会发生错误。



    0赞 · 0采集
  • 大鹏111 2019-06-17

    排序——order by子句

    1、使用order by子句对查询结果排序,默认使用升序排序。

    【a】升序排序——asc

    【b】降序排序——desc

    案例:查询商品价格按升序返回查询结果

    https://img1.mukewang.com/5d0775030001c3c905850304.jpg

    案例2:查询结果按价格降序返回

    https://img2.mukewang.com/5d0775d60001f3d906110294.jpg在order by子句中设置多个排序规则

    案例3:商品的返回结果按照商家的id进行升序的排序,此时如果商品的商家id一样的情况下,商品信息会默认优先显示商品id比较小的商品信息,如果商品的商家信息一致的情况下,该排序规则就无效了,第二个排序规则按照价格进行降序排序,第三个规则,如果所有商家信息id一样,价格也是一样的,此时商品信息按照名称进行升序排序,各个规则之间用逗号进行分隔。

    https://img2.mukewang.com/5d077a3900017bb407770368.jpg


    1赞 · 1采集
  • 大鹏111 2019-06-17

    查询单个对象

    1、Query接口定义了uniqueResult方法,该方法强制返回结果只存在一个实例对象,而不再返回list集合形式的查询结果。

    2、使用uniqueResult方法注意,通过where子句设置恰当的条件,保证符合查询条件的实例对象仅有一个,或者不存在,如果设置的查询条件不当,查询返回的实例对象多余一个,该方法就会抛出异常,终止运行。

    案例:https://img.mukewang.com/5d0756650001f1b105880266.jpg案例2:设置查询条件返回结果不唯一

    https://img3.mukewang.com/5d0773150001929306060348.jpghttps://img1.mukewang.com/5d07733b00016f8605320479.jpg

    0赞 · 0采集
  • 大鹏111 2019-06-17

    四则运算(+、-、*、/):对选择的属性做一些需要的运算。

    1、HQL语句中也可以使用+、-、*、/四则运算。

    2、四则运算可以在where子句和select子句中使用

    案例:查询5件商品价格大于3000元的商品

    https://img2.mukewang.com/5d07542c0001dcda05650307.jpg

    0赞 · 1采集
  • 大鹏111 2019-06-17

    集合运算:HQL语句提供比较特殊的运算符,持久化映射中,存在一对多的映射配置,这里就可以使用集合运算符做相应的判定运算。

    集合运算符:Hibernate框架会在hql解析过程中,解析成相应sql语句时

    把empty——>exists把member of——>in运算。

    1、is [not] empty判断集合类型属性[不]为空,不包含任何元素。

    2、member of判断实例是否属于该集合

    案例:查询订单明细不为空的有效订单

    https://img.mukewang.com/5d075026000115fd10210359.jpg

    0赞 · 0采集
  • 大鹏111 2019-06-17

    逻辑运算:通过逻辑运算符,将逻辑表达式按照逻辑运算规则,形成一个新的逻辑表达式。

    逻辑运算符:and(逻辑与)——如果逻辑表达式运算结果都为true则为true否则就为false、or(逻辑或)——如果逻辑表达式运算结果都为false则为false否则就为true、not(逻辑非)——对布尔运算结果取反。

    https://img1.mukewang.com/5d0745df0001b00710190613.jpg

    案例:查询商品价格在100到5000元之间,并且类型为电脑类型

    https://img3.mukewang.com/5d07469c000122a510240351.jpg

    案例2:查询商品价格在100到5000之间或者是电脑类型

    https://img3.mukewang.com/5d0747ba000115fd10210359.jpg


    0赞 · 0采集
  • 大鹏111 2019-06-17

    字符串模式匹配:通过使用like关键字和通配符,对字符串类型的属性进行匹配运算(模糊查询)。

    通配符:%、_。一个%形式可以匹配任意个字符,一个_形式匹配一个字符。

    案例:查询顾客名字姓张的,并且有两个字的用户。

    https://img4.mukewang.com/5d0736b40001507b06140288.jpg案例2:查询地址在北京的顾客信息(因为北京在地址中不固定,所以使用%通配符)

    https://img.mukewang.com/5d0738530001cde206480289.jpg



    0赞 · 0采集
  • 大鹏111 2019-06-17

    范围运算:判断属性值是否在给定的条件范围之内。

    1、[not] in (列表)————进行的范围运算,in关键字后为候选值列表,该候选值列表可以明确指出也可以是子查询,当属性值在候选列表中存在返回true,否则返回false。

    2、[not] between 值1 and 值2————指定一个值的范围,只要属性值在这个范围内,该运算就返回true值,否则返回false。

    案例:通过in关键字查询用户年龄20和40的用户

    https://img1.mukewang.com/5d070ad20001e8a205550296.jpg

    案例2:查询年龄在20到40之间的用户

    https://img.mukewang.com/5d070b8000015b2506440300.jpg


    0赞 · 0采集
  • 大鹏111 2019-06-17

    null值判断运算

    案例:查询商品描述为null的商品

    https://img2.mukewang.com/5d07084a000153a105940299.jpg

    0赞 · 0采集
  • 大鹏111 2019-06-17

    比较运算:持久化类的属性与给定的查询条件进行比较。

    1、比较运算符:=、<>、<、>、>=、<=。

    2、null值判断————is [not] null,HQL中允许使用相等和不等进行null值判断,Hibernate框架会将x=null解析成x is null,x<>null解析成x is not null。

    案例:查询价格大于400的商品

    https://img2.mukewang.com/5d0703ef00010ffb05610319.jpg


    0赞 · 0采集
  • 大鹏111 2019-06-17

    本章内容简介

    where子句:逻辑表达式,设置查询的条件,来限制返回的查询结果,实际应用情况中,通常要求不是返回持久化类的所有查询结果,尤其是数据量非常庞大时。

    1、比较运算

    2、范围运算

    3、字符串模式匹配

    4、逻辑运算

    5、集合运算

    6、在HQL中使用+-*/运算符

    7、查询单个对象(uniqueResult方法)

    0赞 · 1采集
  • 大鹏111 2019-06-16

    通过distinct返回不重复的查询结果

    distinct关键字:去除查询结果中的重复元素。

    当使用select语句以后,查询结果中的元素就不再保证是唯一的了,比如查询客户持久化类的时候,选择返回性别元素(select sex from Customer c),这时返回的结果就会发生重复,而在一个查询结果中,有两个相同的行,是没有意义的,这时就可以使用distinct关键字(select distinct sex from Customer c)消除查询结果中重复的元素。

    https://img.mukewang.com/5d062f020001eb0006180298.jpg



    0赞 · 0采集
  • 大鹏111 2019-06-16

    持久化类中无参构造方法的必要性:

    当我们通过select语句完成自定义构造器查询,持久化类中是否还需要提供无参构造器呢?

    答:持久化类中需要提供无参构造器。因为在HQL语句中,当指定了查询目标,并且指定了相应构造器后。Hibernate会调用指定的构造器,来进行对象的创建以及数据的封装,但是如果没指定相应的构造器,Hibernate会调用默认的构造器。

    例如:from Seller s指定了查询目标,但没有指定相应构造器,Hibernate框架就会调用默认的构造器。

    0赞 · 0采集
  • 大鹏111 2019-06-16

    select以自定义类型返回查询结果

    1、持久化类中定义相应的构造器,构造器的参数就是我们要返回的属性信息。

    2、select子句中调用定义的构造器来完成相应的查询,以自定义的类型返回查询结果。

    案例:

    https://img2.mukewang.com/5d0626ec00016adf06670318.jpg

    https://img1.mukewang.com/5d0626ec0001c4fb05040186.jpg


    0赞 · 0采集
  • 大鹏111 2019-06-16

    通过select子句指定返回结果类型为Map

    定义:select子句中使用new map指定查询结果的数据类型为map,并需要注意在获取值时,Map中的key值为属性在select语句中的相应索引值(从0开始),并且类型为字符串类型。

    https://img1.mukewang.com/5d05fb6800013c5307140324.jpg


    查询结果与List完全一致的

    https://img.mukewang.com/5d05fb9600018ca203690545.jpg

    Map的get方法除了可以使用属性在select语句中的索引位置来获取查询结果,还可以通过select子句中属性取别名来获取。

    https://img.mukewang.com/5d05fc54000178c509110305.jpg

    0赞 · 0采集
  • 大鹏111 2019-06-16

    通过select子句指定返回的查询结果为list类型。

    定义:select子句中使用new list指定返回的查询结果

    https://img.mukewang.com/5d05f86000013bd606600326.jpg

    0赞 · 0采集
  • 大鹏111 2019-06-16

    使用select指定检索数据以Object[]方式返回查询结果(使用select子句进行查询,可以减少无用的数据传输量)

    1、如果select子句中只是指定了查询的对象和属性,但是没有指定返回的数据类型,默认的查询结果以Object[]形式返回。

    通过别名引用持久化类中属性的信息,返回指定属性的对象。

    案例:通过select子句指定返回对象数组类型的查询结果,首先定义一个from子句(没有使用select子句),这样查询的是所有Seller持久化类的实例。

    https://img4.mukewang.com/5d05efe400016a5d04590156.jpg

    假设查询结果是供一个列表来使用的,列表只需要商家的名称、电话、地址、商家的星级,如果没有使用select子句,该查询的结果是商家所有字段的信息,包括了其它不需要的数据信息,这样就增加了无用的数据传输量,特别是表中的数据非常庞大时,会非常影响程序的性能,这时就需要使用select子句返回只需要的属性信息来提高程序的运行效率,这里可以通过别名来引用持久化类中的相应属性信息。

    https://img.mukewang.com/5d05f1fe0001ad4b06560477.jpg查询结果:
    https://img1.mukewang.com/5d05f24b000199d103610543.jpg

    特殊情况注意:当使用select语句只查询对象的一个属性时,返回的数据类型就不是对象数组,而是对象Object。

    https://img2.mukewang.com/5d05f4dc0001f65204390332.jpgselect子句中不是一定使用别名来访问对象的属性,实际应用开发中,from子句中通常不会查询一个目标实体,如果多个实体目标中包含有同一个属性,使用别名可以区分,排除错误的产生。

    https://img2.mukewang.com/5d05f5e60001ec0c10170664.jpg

    0赞 · 0采集
  • 大鹏111 2019-06-15

    使用select语句指定检索数据以哪种数据类型返回查询结果。

    1、以Object[]形式返回选择的属性

    2、以List集合形式返回选择的属性

    3、以map形式返回选择的的属性

    4、以自定义类型返回选择的属性

    5、获取独特的结果——distinct关键字




    0赞 · 0采集
  • 大鹏111 2019-06-13

    from子句中别名的使用:

    通常对持久化类进行查询时,为查询的类指定别名,使用AS关键字使用别名,也可以省略,使用别名的目的是在HQL语句的其他部分通过别名引用该类,特别是查询的目标不止一个的时候,使用别名特别方便。

    别名的命名规范:别名与持久化类名相同

    https://img3.mukewang.com/5d02441f0001acde05690146.jpg

    0赞 · 0采集
  • 大鹏111 2019-06-13

    from子句中持久化类的引用

    1、from子句引入持久化类,不需要引入持久化类的全限定名,直接引入类名。

    https://img2.mukewang.com/5d01c7a60001be5e09950268.jpg

    2、auto-import(自动引入)缺省情况:hibernate框架中解析HQL语句时,会根据映射配置信息,自动完成持久化类的导入。

    0赞 · 0采集
  • 大鹏111 2019-06-12

    from子句简介及简单案例实现

    1、HQL语句最简形式

    2、from指定了HQL语句查询主体——持久化类及其属性

    0赞 · 0采集
  • 大鹏111 2019-06-12

    本章内容

    1、from子句的介绍。

    2、from子句中持久化类的引用。

    3、别名的使用

    0赞 · 1采集
  • 大鹏111 2019-06-11

    Query接口应用编程实例——数据库分析(通过编程实例演示Query对象实例的创建,以及HQL语句查询的执行)

    编程实例描述:使用的数据库是一个简单的网上商店的例子,存储了网上商店运转所需的最基本的数据信息,包括商家信息、商品信息、客户信息、订单信息,其中商家信息和商品信息所关联,每一项商品均属于某个商家,一个商家可以有多个商品,构成了一对多的关系,在网上商店进行出售,而订单信息记录了订单的交易时间,交易金额以及订单状态等信息订单和与客户信息所关联,一张订单属于某个客户,而一个客户可以有多个订单,一个订单可以多个订单明细,一个订单明细只能属于某个订单,每张订单信息记录了购买的商品信息,以及该商品的购买数量。

    https://img2.mukewang.com/5cfef45f0001418408970488.jpg

    表结构:

    https://img1.mukewang.com/5cfef5d00001045609090561.jpg

    https://img2.mukewang.com/5cfef5d000010c7409290608.jpg

    商品表的所属商家是外键,关联商家表

    https://img3.mukewang.com/5cfef602000146b809680569.jpg订单表的所属客户是外键,和客户表相关联

    https://img4.mukewang.com/5cfef6420001001310390568.jpg订单明细表的所属订单和订单商品是外键,和订单表与商品表相关联

    https://img.mukewang.com/5cfef68d0001279b09570553.jpg


    0赞 · 1采集
  • 大鹏111 2019-06-10

    Query接口简介

    org.hibernate.Query接口

    1.Query接口中有定义执行查询的方法,该方法完成了HQL语句的解析和执行过程,并返回查询的结果(就像sql语句如果没有了jdbc接口,它也只是一个字符串变量,HQL也一样,hibernate负责解析HQL语句,然后根据我们的映射配置信息,把HQL语句解析成相应的SQL语句,来执行数据库的查询操作,这一个过程的完成依靠的就是Query接口)。

    https://img3.mukewang.com/5cfdcf3c00016e9710860293.jpg

    2、Query接口支持方法链编程风格,使得程序代码更为简洁(简单来说就是调用方法后,返回的方法结果还是调用方法的这个对象,我们可以调用方法后,调用该对象的其他方法,这样我们就可以用一条程序语句完成多个方法的调用和执行)。适用场景:查询参数是动态设置的,特别是多个参数的设置。

    Query实例的创建

    【a】通过Session接口的createQuery()方法创建Query实例。

    【b】createQuery方法包含一个HQL语句参数,该参数就是要执行的HQL查询语句。

    Query执行查询

    【a】Query接口的list()方法执行HQL查询。

    【b】list()方法查询完之后,返回结果数据类型为java.util.List,List集合中存放符合查询条件的持久化对象。

    0赞 · 1采集
  • 大鹏111 2019-06-10

    本章内容简介

    1、了解Hibernate框架中的org.hibernate.Query接口。

    2、Query实例对象的创建。

    3、使用创建好的Query对象进行HQL语句查询

    0赞 · 1采集
  • 大鹏111 2019-06-06

    初学HQL要注意的问题

    【1】HQL是面向对象的查询语言,查询主体是持久化类,对Java类与属性大小写敏感。(SQL查询主体是数据表,表名和属性名是不敏感的)

    【2】HQL对关键字不区分大小写(规范关键字都小写)。

    0赞 · 0采集
  • 大鹏111 2019-06-06

    HQL语句形式

    【1】select...指定查询结果中的对象和属性,并指定以何种数据类型来返回,位置在HQL语句中排在最前面。

    【2】from...指定HQL语句的查询目标,必须项(映射配置的持久化类及其属性)

    【3】where...逻辑表达式,设置查询的条件,限制返回查询结果的范围

    【4】group by...分组查询子句

    【5】having...对分组条件进行限制

    【6】order by...指定查询结果中实例对象的排序

    https://img3.mukewang.com/5cf88be90001855911900535.jpg

    2赞 · 0采集
  • 大鹏111 2019-06-06

    HQL定义(Hibernate Query Language)Hibernate框架提供的查询语言,HQL是面向对象的查询语言,查询主体是映射配置的持久化类及其属性(SQL查询主体是数据库表)HQL提供了丰富灵活的查询特性,Hibernate官方推荐查询方式。



    1赞 · 0采集
  • 大鹏111 2019-06-06

    本章内容

    1、HQL定义

    2、HQL语句形式

    3、初学HQL注意的问题

    0赞 · 0采集
数据加载中...
开始学习 免费