zoukankan      html  css  js  c++  java
  • JPQL详解

    JPA
    在说jpql之前必须要说一下什么是JPA,否则在后续学习的时候,你会弄混的。JPA是一种规范,什么是规范呢,规范就是一个钥匙可以开这把锁。一般对于规范来说我们都是用接口,如果有人要我们则实现我们的接口就可以了,所以我们针对的面向接口编程。。另外再说一个新词叫做ORM。他表示什么呢?Object·/Relation Mapping 对象/关系数据库映射,他完成的是面向对象的编程语言到关系型数据库的映射,所以你可以理解为ORM其实就是应用程序和数据库的桥梁。

    JPA规范本质上就是一种ORM规范。

    下面说一下关于JPA规范和JPA实现他们之间的关系,以及JPQL和HIbernate等之间的关系。其实用一张图就可以说明他们之间的关系



    JPA从哪来,名词有那些
    上面基本上都是在讲解什么是jpa和jpa实现的其他技术有哪些,他们之间的概念,下面介绍的是JPA来自于哪里?

    JPA是在Ejb3出现的时候同时出现的,他的出现其实上代替了我们EJB2中的实体bean,但是JPA并不属于我们EJB3规范的内容,他是一个独立的规范,他的应用场景不仅仅是在javaEE中可以用,而且也可以在javase中可以。

    名词介绍:
    1。实体:实体就是一个普通的POJO,ps当你看到POJO的时候一定不要感觉很难,POJO其实就是一个普通的java类而已,只是名字高大尚了而已。实体的作用就是辅助我们orm.xml映射文件或者是Annotation,orm.xml是针对hibernate的,Annotation针对的Ejb注解形式的。实体和底层数据库之间进行映射的。
    2。EntityManager:上面所说的实体是与我们数据库映射的,但是没有起到持久化的作用,只有用上EntityManager的实体进行操作的时候才会有持久化能力,什么是持久化能力呢?下面的博客链接讲解了

    https://blog.csdn.net/sunyadongwanghbjm/article/details/1765073

    3。JPQL查询:Hibernate提供的是HQL查询,而JPA提供的是JPQL查询语言



    JPQL
    前面的前提终于讲完了,下面我们来说一下关于JPQL的内容

    JPQL与Sql比较
    jpql与SQL的区别就是SQL是面向对象关系数据库,他操作的是数据表和数据列,而jpql操作的对象是实体对象和实体属性

    JPQL 语句基本格式
    下面是JPQL的基本格式,根据基本格式我们执行jpql语句

    select 实体别名.属性名, 实体别名.属性名 from 实体名 as 实体别名 where 实体别名.实体属性 op 比较值
    1
    具体事例

    select p.name from book as p
    1
    在写语句的时候我们可能需要使用到参数,如果是位置参数使用“?” ,如果是参数则使用 “:XX “

    JPQL 查询基本格式
    jpql的查询语句设计非常简单。主要是由于Query接口来完成的,而我们的Query接口是由EntityManager创建出来的。ps上面提过什么是EntityManage。

    Query createNamedQuery(String name):创建查询的名称来创建一个命名查询,使用sql和jpql都可以
    Query createNativeQuery(String SQLString)根据的原生的sql语句查询
    QuerycreateQuery(String jpqlString)根据指定的JPQL语句创建一个查询
    jpql传参数我们使用的Query setParmeter(String name, Object value),还有其他是日期类型的,大家可以在查阅

    JPQL 执行基本格式
    当我们的参数和语句完事之后我们就应该执行,对于jpql执行分为以下几种

    List getResultList()执行JPQL的select语句,并且返回的是list集合
    Object getSingleResult()执行返回的那个结果的select语句
    int executeupdate()表示执行批量的删除和更新
    Query setFirstResult(int startPosition)设置查询结果从第几条记录开始
    Query setMaxResults(int maxResult)表示设置查询最多返回几条语句

    T

  • 相关阅读:
    chapter23:软件安装RPM,SRPM与YUM之(0)-软件管理器的简介
    chapter22:源码与Tarball之(3)-函数库的管理
    chapter22:源码与Tarball之(2)-Tarball的管理与安装
    Akamai在内容分发网络中的算法研究(翻译总结)
    常用机器性能评估工具
    利用神经网络编辑图片的调研
    Redis命令总结及其基础知识讲述
    MySQL主从复制与主主复制
    MySQL查询优化
    降低Redis内存占用
  • 原文地址:https://www.cnblogs.com/baobeiqi-e/p/10534903.html
Copyright © 2011-2022 走看看