zoukankan      html  css  js  c++  java
  • JPA ---- EntityManager介绍

    一、 EntityManager是JPA中用于增删改查的接口,它的作用相当于一座桥梁,连接内存中的java对象和数据库的数据存储。

      Entity生命周期中的Managed,Detached,Removed三种状态变化过程,如下图所示:

      New:瞬时对象,尚未有id,还未和Persistence Context建立关联的对象。

           Managed:持久化受管对象,有id值,已经和Persistence Context建立了关联的对象。

           Datached:游离态离线对象,有id值,但没有和Persistence Context建立关联的对象。

           Removed:删除的对象,有id值,尚且和Persistence Context有关联,但是已经准备好从数据库中删除

       1、entityManager.persist(Object entity);  新增数据;

           如果entity的主键不为空,而数据库没有该主键,会抛出异常;
           如果entity的主键不为空,而数据库有该主键,且entity的其他字段与数据库不同,persist后不会更新数据库;
     
       2、entityManager.find(Class<T> entityClass, Object primaryKey);  根据主键查找数据;
           如果主键格式不正确,会抛出illegalArgumentException异常;
           如果主键在数据库未找到数据返回null;
     
       3、entityManager.remove(Object entity);  删除数据;
           只能将Managed状态的Entity实例删除,由此Entity实例状态变为Removed;
     
       4、entityManager.merge(T entity);   将Detached状态的Entity实例转至Managed状态;
     
       5、entityManager.clear();  将所有的Entity实例状态转至Detached状态;
     
       6、entityManager.flush();   将所有Managed状态的Entity实例同步到数据库;
     
       7、entityManager.refresh(Object entity); 加载Entity实例后,数据库该条数据被修改,refresh该实例,能得到数据库最新的修改,覆盖原来的Entity实例;
     
       8、entityManager.unwrap(Session.class):获取Session对象
     
     
  • 相关阅读:
    SQL Server 系统视图
    T-SQL 批处理
    T-SQL游标
    SQL Server执行计划的理解
    SQL Server 非聚集索引的覆盖,连接,交叉和过滤 <第二篇>
    SQL Server 分区表
    SQL Server 文件和文件组
    SQL Server逻辑读、预读和物理读
    mysql 报错ERROR 1064 (42000),原因使用了mysql保留字 (right syntax to use near 'groups)
    docker Redis的主从配置
  • 原文地址:https://www.cnblogs.com/Big-Boss/p/13716512.html
Copyright © 2011-2022 走看看