一、hibernate实体创建规则

1、hibernate---->持久层ORM 映射框架,专注于数据的持久化工作。
2、持久化类创建规则
  --->1、提供无参数的构造方法
     2、私有化、对石油的属性提供get、set方法
     3、尽力提供包装类的类型 
     4、持久化类需要提供oid.与数据库中的主键列对应
     5、hibernate使用cglib代理生成代理对象.代理对象是继承被代理对象.如果被final修饰.将无法生成代理. 
3、主键类型
1、自然主键:把含有业务含义的字段作为主键(非空,不能重复、不可修改)
     2、代理主键:不具备业务含义的字段作为主键
4 主键策略
     1、identity : 主键自增.由数据库来维护主键值.录入时不需要指定主键.
        --->native:hilo+sequence+identity 自动三选一策略.
        --->sequence: Oracle中的主键生成策略.
     2、assigned:自然主键生成策略. hibernate不会管理主键值.由开发人员自己录入.

  

二、hibernate对象状态


三、hibernate 事务

1、特性
    a :原子性
    c :一致性
    i :隔离性
    d: 持久性
2、事务并发问题
    脏读、不可重复读、幻读|虚读
3、事务隔离级别
注意:数据库使用时,隔离级别越高,安全性越高,性能就越低。
    建议:READ_COMMITTED ----->oracle(默认)
       REPEATABLE_EAD ----->mysql(默认)

四、hibernate 一级缓存

1、目的:
    缓存:提高效率.hibernate中的一级缓存也是为了提高操作数据库的效率.
2、方案一
3、方案二

五、查询

HQL查询:
  1、Hibernate独家查询语言,属于面向对象的查询语言
  2、简单查询
    String hql = "from cn.xxx.xxx.User";
    //String hql = "from User";
    Query query = session.createQuery(hql);//传入hql
    List<Customer> Lists = query.list(); //接收list返回结果
    接收唯一查询结果-----》 query.uniquerResult();
  3、条件查询
     占位符 ? or :属性名 :
    1--> String hql1 = "from User where id = ?";
       Query query = session.createQuery(hql1);
        query.setParameter(0,2);//设置参数
        User c = (User)query.uniqueResult();//获取结果
    2--> String hql2 = "from User where id=:id";
        Qusery query = session.createQuery(hql2);
        query.setParameter(0,1);
        User c = (User)query.uniqueResult();
  4、分页查询
      1 -->SetFirstResult(1); 起始位
       -->setMaxResults(2);  可以理解为最大步长
      2---->基本和上面步骤一致为query 设置这两个属性就行啦  
Criteria:
  1、Hibernate独家的无语句面向对象查询(建议不要使用sql的查询相关的信息 )
  2、
    1--->简单
      Critera critera = session.createCriteria(User.class);创建查询语句
      List<User> list = critera.list();//获取对象
    2--->条件
      在条件查询中可以使用的Restriction的方法
        

      Criteria critera = session.createCriteria(User.class);
      critera.add(Restriction.eq("id",1l));//查询id为1
      User c = (User)criteria.uniqueResult();
      
  3--->分页 :分页同样也是调用hql中的那两个方法名
    4--->查询总数:采用这个方法setProjection criteria.setProjection(Projections.rowCuount());
原生查询:就是使用原生的sql查询,建议在复杂查询的时候使用他不建议使用hql 和 Criteria
简单查询1:
public void fun(){
  //获取session对象
  Session session = HibernateUtis.openSession();
  //事务控制
  Transction tx = session.beginTransction();
  //编写执行sql
  String sql = "select * from user";
  //创建查询对象
  SQLQuery query = session.createSQLQuery(sql);
  //run ----》query 方法
  List<Object[]> list = query.list(); // 返回的是数组list
  for(Object[] obj: list){        //遍历数组list
    Syso(Arrays.toString(obj));//此处简写
  }
}

简单查询2:

String sql = "select * from user";
SQLQuery query = createSQLQuery(sql);
query.andEntity(User.class);
List<User> list = query.list();//返回对象list
System.out.println(list);

分页查询:

//此处省略部分代码

String sql = "select * from user limit ?,?";

SQLQuery query = session.createSQLQuery(sql);

query.setParameter(0,0);
query.setParameter(1,1); query.addEntity(User.class); List<User> list = query.list(); System.out.println(list);

条件查询:

String sql = "select * from User where id = ?";
//创建查询对象
SQLQuery query = session.createSQLQuery(sql);
//设置参数
query.setParameter(0,11);
//指定结果集封装对象
query.addEntity(User.class);
//调用方法
List<user> list = query.list(); Sysout.out.println(list);

Hibernate-02的更多相关文章

  1. hibernate 02之helloworld

    1.安装插件 安装方法说明(hibernatetools-.Final): Help --> Install New Software... Click Add... In dialog Add ...

  2. Rhythmk 学习 Hibernate 02 - Hibernate 之 瞬时状态 离线状态 持久化状态 三状态

    by:rhythmk.cnblogs.com 1.Hibernate 三种状态: 1.1.三种定义(个人理解,不一定准确):  瞬时状态(transient):    不被session接管,且不存在 ...

  3. hibernate 映射 多对一

    一对多和上文讲的多对一两种映射关系,其实就是站在相反的角度考虑同样的事情. 一对多和多对一映射原理是一样的,都在多的一端加入一个外键指向一的一端.也就是说,在关系数据库的表中,他们的表及表字段都是一样 ...

  4. Hibernate 系列 02 - Hibernate介绍及其环境搭建

    引导目录: Hibernate 系列教程 目录 昨晚喝多了,下午刚清醒,继续搞Hibernate.走起. 觉得还行的话,记得点赞哈,给我这个渣渣点学习的动力.有错误的话也请指出,省的我在错误上走了不归 ...

  5. 02 Hibernate错题分析

    解析:使用final修饰的成员变量是常量 解析:不存在StateMoreSession的对象 解析:一个PreparedStatement 可以执行多次executQuery方法 解析:A   使用H ...

  6. 02.Hibernate映射基础

    前言:Hibernate的核心功能是根据数据库到实体类的映射,自动从数据库绑定数据到实体类.使我们操作实体类(Java对象)就能对数据库进行增.删.查.改,而不用调用JDBC API使数据操作变得简单 ...

  7. Hibernate逍遥游记-第5章映射一对多-02双向(<set>、<key>、<one-to-many>、inverse、cascade="all-delete-orphan")

    1. <?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hi ...

  8. Hibernate-ORM:02.Hibernate增删改入门案例

    ------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 本笔者使用的是Idea+mysql+maven做Hibernate的博客,本篇及其以后都是如此! 首先写好思路 ...

  9. Hibernate事务以及一级缓存02

    一. Hibernate中的事务 1. 事务的回顾 1.1 什么是事务(Transaction)(面试重点) 是并发控制的单元,是用户定义的一个操作序列.这些操作要么都做,要么都不做,是一个不可分割的 ...

  10. 02.Hibernate配置文件之映射配置文件

    映射文件,即xxx.hbm.xml的配置文件 <class>标签:用来将类与数据库表建立映射关系 属性: name:类中的全路径 table:表名(如果类与表名一致,那么table属性可以 ...

随机推荐

  1. 关于netty的多个handler链式模式

    1. 老规矩, 引入我们喜闻乐见的maven依赖 <dependency> <groupId>io.netty</groupId> <artifactId&g ...

  2. windows下 zookeeper dubbo 安装+配置+demo 详细图文教程

    Java集群优化——dubbo+zookeeper构建 互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,Dubbo是一个分布式服务框架,在这 ...

  3. Linux 常用命令十四 killall和pkill

    用killall杀死所有同名的进程. wang@wang:~/workpalce/git$ ps -aux | grep vim wang pts/ S+ : : vim a wang pts/ S+ ...

  4. bzoj 2152: 聪聪可可【点分治】

    裸的点分治,运算在模3下进行然后统计答案的时候统计余1的*余2的*2+余0的^2 #include<iostream> #include<cstdio> using names ...

  5. sigaction函数的功能

    sigaction函数的功能是检查或修改与指定信号相关联的处理动作(可同时两种操作). 他是POSIX的信号接口,而signal()是标准C的信号接口(如果程序必须在非POSIX系统上运行,那么就应该 ...

  6. Java中的流(5)大数据流的分段读取

    来自文件 或 网络的InputStream数据量可能很大,如果用流的大小申请byte[],可能内存不足报错. 解决方案:分段读取 InputStream的方法int available()返回本次可读 ...

  7. AJPFX实践 java实现快速排序算法

    快速排序算法使用的分治法策略来把一个序列分为两个子序列来实现排序的思路: 1.从数列中挑出一个元素,称为“基准“2.重新排序数列,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面 ...

  8. mysql之流程控制

    目录 分支结构 循环结构 分支结构: 1.if condition then [statement] elseif condition then [statement] else [statement ...

  9. 用css制作圆环图表 (vue,sass)

    效果图: 思路 :在一个容器里再放两个矩形,每个矩形都占一半,给这两个矩形都设置溢出隐藏,当去旋转矩形里面的圆形的时候,溢出部分就被隐藏掉了,这样就可以达到想要的效果. 代码-html: <di ...

  10. Apache Tomcat 之路(一 基本概念)

    关于apache tomcat 基本概念(https://tomcat.apache.org/tomcat-7.0-doc/index.html) 1.tomcat 是servlet/jsp 容器,对 ...