Hibernate 双向ManyToMany 究极解决 新增-删除-修改-查询(2)

本文主要是介绍Hibernate 双向ManyToMany 究极解决 新增-删除-修改-查询(2),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

DAO设计:

已经设计好数据实体以及关联关系了,接下来DAO层的编码,这部分没什么东西,可以直接无视

HibernateUtil:

package org.taomujian.db;import org.hibernate.SessionFactory;import org.hibernate.cfg.Configuration;public class HibernateUtil {private static final SessionFactory sessionFactory = buildSessionFactory();private static SessionFactory buildSessionFactory() {try {// Create the SessionFactory from hibernate.cfg.xmlreturn new Configuration().configure().buildSessionFactory();}catch (Throwable ex) {// Make sure you log the exception, as it might be swallowedSystem.err.println("Initial SessionFactory creation failed." + ex);throw new ExceptionInInitializerError(ex);}}public static SessionFactory getSessionFactory() {return sessionFactory;}}

 OrgDAO:

package org.taomujian.dao;import org.hibernate.Session;
import org.taomujian.db.HibernateUtil;
import org.taomujian.model.Org;public class OrgDAO{public void saveOrg(Org org){if(null==org)	return ;Session session = HibernateUtil.getSessionFactory().getCurrentSession();session.beginTransaction();session.persist(org);session.getTransaction().commit();}public void delOrg(Org org){Session session = HibernateUtil.getSessionFactory().getCurrentSession();session.beginTransaction();session.delete(org);session.getTransaction().commit();}public void mergeOrg(Org org){if(null==org)	return ;Session session = HibernateUtil.getSessionFactory().getCurrentSession();session.beginTransaction();session.merge(org);session.getTransaction().commit();}public Org getOrg(String id){Session session = HibernateUtil.getSessionFactory().getCurrentSession();session.beginTransaction();Org org = (Org)session.get(Org.class, id);session.getTransaction().commit();return org;}
}

 RoleDAO:

 

package org.taomujian.dao;import org.hibernate.Session;
import org.taomujian.db.HibernateUtil;
import org.taomujian.model.Role;public class RoleDAO {/*** 保存role记录,可以只单独保存role,也可以完整的保存role以及org和级联关系* * @param role*/public void saveRole(Role role){if(null==role)	return ;Session session = HibernateUtil.getSessionFactory().getCurrentSession();session.beginTransaction();session.persist(role);session.getTransaction().commit();}public void mergeRole(Role role){if(null==role)	return ;Session session = HibernateUtil.getSessionFactory().getCurrentSession();session.beginTransaction();session.merge(role);session.getTransaction().commit();}/*** 根据角色的ID获取一条role数据* @param id* @return*/public Role getRole(String id){Session session = HibernateUtil.getSessionFactory().getCurrentSession();session.beginTransaction();Role role = (Role)session.get(Role.class, id);System.out.println(role.getOrgList());session.getTransaction().commit();return role;}/*** 删除角色:* @param id*/public void removeRole(Role role){Session session = HibernateUtil.getSessionFactory().getCurrentSession();  session.beginTransaction();   session.delete(role);session.getTransaction().commit();     }}

 

这篇关于Hibernate 双向ManyToMany 究极解决 新增-删除-修改-查询(2)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/819163

相关文章

MyBatis-Plus逻辑删除实现过程

《MyBatis-Plus逻辑删除实现过程》本文介绍了MyBatis-Plus如何实现逻辑删除功能,包括自动填充字段、配置与实现步骤、常见应用场景,并展示了如何使用remove方法进行逻辑删除,逻辑删... 目录1. 逻辑删除的必要性编程1.1 逻辑删除的定义1.2 逻辑删php除的优点1.3 适用场景2.

MySQL中between and的基本用法、范围查询示例详解

《MySQL中betweenand的基本用法、范围查询示例详解》BETWEENAND操作符在MySQL中用于选择在两个值之间的数据,包括边界值,它支持数值和日期类型,示例展示了如何使用BETWEEN... 目录一、between and语法二、使用示例2.1、betwphpeen and数值查询2.2、be

解决idea启动项目报错java: OutOfMemoryError: insufficient memory

《解决idea启动项目报错java:OutOfMemoryError:insufficientmemory》:本文主要介绍解决idea启动项目报错java:OutOfMemoryError... 目录原因:解决:总结 原因:在Java中遇到OutOfMemoryError: insufficient me

maven异常Invalid bound statement(not found)的问题解决

《maven异常Invalidboundstatement(notfound)的问题解决》本文详细介绍了Maven项目中常见的Invalidboundstatement异常及其解决方案,文中通过... 目录Maven异常:Invalid bound statement (not found) 详解问题描述可

MyBatis-Plus使用动态表名分表查询的实现

《MyBatis-Plus使用动态表名分表查询的实现》本文主要介绍了MyBatis-Plus使用动态表名分表查询,主要是动态修改表名的几种常见场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录1. 引入依赖2. myBATis-plus配置3. TenantContext 类:租户上下文

MySQL基本表查询操作汇总之单表查询+多表操作大全

《MySQL基本表查询操作汇总之单表查询+多表操作大全》本文全面介绍了MySQL单表查询与多表操作的关键技术,包括基本语法、高级查询、表别名使用、多表连接及子查询等,并提供了丰富的实例,感兴趣的朋友跟... 目录一、单表查询整合(一)通用模版展示(二)举例说明(三)注意事项(四)Mapper简单举例简单查询

nacos服务无法注册到nacos服务中心问题及解决

《nacos服务无法注册到nacos服务中心问题及解决》本文详细描述了在Linux服务器上使用Tomcat启动Java程序时,服务无法注册到Nacos的排查过程,通过一系列排查步骤,发现问题出在Tom... 目录简介依赖异常情况排查断点调试原因解决NacosRegisterOnWar结果总结简介1、程序在

C#实现插入与删除Word文档目录的完整指南

《C#实现插入与删除Word文档目录的完整指南》在日常的办公自动化或文档处理场景中,Word文档的目录扮演着至关重要的角色,本文将深入探讨如何利用强大的第三方库Spire.Docfor.NET,在C#... 目录Spire.Doc for .NET 库:Word 文档处理利器自动化生成:C# 插入 Word

MySQL中的DELETE删除数据及注意事项

《MySQL中的DELETE删除数据及注意事项》MySQL的DELETE语句是数据库操作中不可或缺的一部分,通过合理使用索引、批量删除、避免全表删除、使用TRUNCATE、使用ORDERBY和LIMI... 目录1. 基本语法单表删除2. 高级用法使用子查询删除删除多表3. 性能优化策略使用索引批量删除避免

MySQL 数据库进阶之SQL 数据操作与子查询操作大全

《MySQL数据库进阶之SQL数据操作与子查询操作大全》本文详细介绍了SQL中的子查询、数据添加(INSERT)、数据修改(UPDATE)和数据删除(DELETE、TRUNCATE、DROP)操作... 目录一、子查询:嵌套在查询中的查询1.1 子查询的基本语法1.2 子查询的实战示例二、数据添加:INSE