javax.persistence.EntityManager 用法

javax.persistence.EntityManager

是一个PA接口

发布
接口EntityManager

接口用于与持久化上下文交互。

一个EntityManager实例与持久化上下文相关的。一个持久化上下文是一组中的实体实例的任何持久的实体的身份有一个独特的实体实例。在持久性上下文中,实体实例及其生命周期管理。这个EntityManagerAPI是用于创建和删除持久的实体实例,根据主键找到实体,并查询实体。

实体可以通过一个给定的管理设置EntityManager实例是由一个存储单元定义。一个存储单元定义的所有类相关或由应用程序分组设置,且必须放在他们的映射到一个数据库。

如:

public class UserServiceImpl implements UserService {
    
    @PersistenceContext
    private EntityManager entityManager;

public List<GrantedAuthority> getAuthoritiesByUserId(Long userId) {
        List<GrantedAuthority> gaList = new ArrayList<GrantedAuthority>();
        String sql = "select distinct ra.authority as 'authority' from user_role ur,role r,role_authority ra where ur.roles_id=r.id and r.id=ra.role_id and ur.users_id="+userId;
        Query query = entityManager.createNativeQuery(sql);
        List<String> authorityList = query.getResultList();
        for(String authority:authorityList){
            gaList.add(new GrantedAuthorityImpl(authority));
        }
        return gaList;
    }

private void testEntityManager(){
        
        Query query = entityManager.createNativeQuery("select distinct ra.authority as 'authority' from user_role ur,role r,role_authority ra where ur.roles_id=r.id and r.id=ra.role_id and ur.users_id=2");
        List<String> roleIdList = query.getResultList();
        
        User user = entityManager.find(User.class, 1);
        TypedQuery<User> userTypedQuery = entityManager.createQuery("from User user", User.class);
        List<User> userList = userTypedQuery.getResultList();
    }

}

常见用法:

  • persist() :添加实体Bean
  • flush() :将实体的改变立刻刷新到数据库中
  • merge () :比较麻烦,用好了很不错,配合flush
  • Remove() :删除对象
  • createQuery() :返回Query对象,以执行JPQL语句
  • createNativeQuery() :返回Query对象,以执行SQL语句
  • refresh() :刷新实体Bean,以得到对新对象
  • contains(): 检测实体当前是否被管理中
  • clear() 分离所有当前正在被管理的实体

更多EntityManager用法,请参考api文档:https://www.objectdb.com/api/java/jpa/EntityManager

猜你喜欢

转载自blog.csdn.net/bird_tp/article/details/83652754