Hibernate(八)__级联操作、struts+hibernate+接口编程架构

级联操作

所谓级联操作就是说,当你进行主对象某个操作时,从对象hibernate自动完成相应操作。

比如: Department <---->Student 对象关系,我希望当我删除一个department ,那么就自动删除该部门的所有学生。

再比如: bbs项目主帖<---->回帖 , 把主帖删除,那我们就希望把该主帖的回帖自动删除,这样我们可以使用级联(cascade)操作。

案例:如何配置级联操作,当删除某个部门的时候,我们自动删除其学生.

首先我们在配置文件中修改:

<!-- 配置one-to-many关系cascade="delete" 当删除该部门的时候(主对象,则级联删除它的学生从对象) -->

<set name="stus" cascade="delete">

<!-- 指定Student类对应的外键 -->

<key column="dept_id" />

<one-to-many class="Student" />

</set>

java代码中操作:

Department department=new Department();

department.setName("业务部门");

Student stu1=new Student();

stu1.setName("小红") ;

stu1.setDept(department);

Student stu2=new Student();

stu2.setName("小明");

stu2.setDept(department);

session.save(department);

session.save(stu1);

session.save(stu2);

Department department=(Department) s.get(Department.class, 41);

s.delete(department);

save-update

配置文件:

<set name="stus" cascade="save-update">

<!-- 指定Student类对应的外键 -->

<key column="dept_id" />

<one-to-many class="Student" />

</set>

java代码:

1.Department department=new Department();

department.setName("业务部门");

Student stu1=new Student();

stu1.setName("小红");

stu1.setDept(department);

Student stu2=new Student();

stu2.setName("小明");

stu2.setDept(department);

session.save(department);

虽然设置了级联操作,但是这种情况下是只会保存部门的,因为没有设置从部门到学生的反向外键引用。

可是如果在学生这边设置级联操作(学生是持有部门的外键引用的),当保存学生时,就可以将部门一并保存

当还是从部门这边做操作时,要改成下面操作才行:

2.Department department=new Department();

department.setName("业务部门3");

Student stu1=new Student();

stu1.setName("小红");

Student stu2=new Student();

stu2.setName("小明");

Set<Student> students=new HashSet<Student>();

students.add(stu1);

students.add(stu2);

department.setStus(students);                 //明确使用集合关系保存

s.save(department);

说明:

① 在集合属性和普通属性中都能使用cascade

② 一般讲cascade配置在one-to-many(one的一方,比如Employee-Department),和one-to-one(主对象一方)

struts+hibernate+接口编程

案例:留言本

这是韩顺平老师所讲hibernate案例中的一张框架图。从上往下分别是web层、业务层、dao层、hibernate层、数据库层。

在这个地方重点要学习是这个框架中的接口编程的方式,关注程序设计结构

在框架中接口使得web层和业务层达到解耦的目的。在接口中声明方法,在业务层中将其方法实现,可是在业务层中实现的方法可能需要改变,

为了在web层中保持代码的不变性,在web层我们使用接口调用方法即可,

UsersServiceInter  usersServiceInter=new UsersServiceImp();

而在我们学习使用Spring后,可以通过xml文件配置方法的方式配置 UsersServiceImp()即可,这样解耦性更高了。

还有就是定义基础接口和基础实现类。因为在MessageServiceInter和UserServiceInter中可能有公共的方法,为了增强代码的复用性,添加一个

基础接口,而只在MessageServiceInter和UserServiceInter定义自己的特有方法。同时BaseServiceImpl是一个抽象类,它可以不完全实现

BaseServiceInter中的方法,因为有些方法都需要它的继承者各自独特实现而不定义统一方法实现

时间: 2024-10-23 02:19:41

Hibernate(八)__级联操作、struts+hibernate+接口编程架构的相关文章

【Hibernate学习】——级联操作

级联策略:负责控制关联两端对象到对象的级联关系的操作,包括更新.删除等,也就是说对一个对象进行更新.删除时,其它对象也受影响,比如我删除一个对象,那么跟它是多对一关系的对象也全部被删除. 在前面用了抓取策略之后,后面试了一下级联操作的注解:cascadeType.MERGE方式 @OneToOne(cascade={CascadeType.MERGE}) @JoinColumn(name="company_id") publicCompany getCompany() { return

Hibernate的Cascade——级联操作

在Hibernate中,针对持久化实体的配置文件中有Cascade这样一个属性,顾名思义就是级联,也就是说在操作当 前实体时,针对当前实体的操作会影响到相应配置的关联实体.比如针对当前实体进行保存操作时,会同时保存 与其关联的实体,当然这种额外操作的产生取决于你是否在当前实体的配置文件中对关联实体的元素配置了 Cascade属性. 而需要进行级联的操作可能涉及到增加,修改,删除等相应的数据库操作,具体Cascade的取值则 分为多种,如all,表示针对所有操作都会进行级联,如save-updat

Hibernate多对多级联操作

表与表之间关系回顾(重点) 2 多对多 (1)订单和商品关系,一个订单里面有多个商品,一个商品属于多个订单 (2)用户和角色多对多关系 - 用户: 小王.小马.小宋 - 角色:总经理.秘书.司机.保安 ** 比如小王 可以 是总经理,可以是司机 ** 比如小宋 可以是司机,可以是秘书,可以保安 ** 比如小马 可以是 秘书,可以是总经理 -          一个用户里面可以有多个角色,一个角色里面可以有多个用户 (3)多对多建表:创建第三张表维护关系 Hibernate多对多操作 多对多映射配

八、python操作excel及网络编程和异常处理

一.python操作excel 1.读excel,xlrd模块用来读excel # book = xlrd.open_workbook(r'students.xlsx')#打开excel# print(book.sheet_names())#获取所有sheet的名字# sheet = book.sheet_by_index(0)#根据sheet页的位置去取sheet# sheet2 = book.sheet_by_name('Sheet2')#根据sheet页的名字获取sheet页# print

hibernate的中的查询与级联操作

1.Criteria查询接口适用于组合多个限制条件来搜索一个查询集. 要使用Criteria,需要遵循以下步骤: *创建查询接口: Criteria criteria=session.createCriteria(User.class); *设置查询条件: criteria.add(Restrictions.gt("age",10); *查询数据:      List<User> list=criteria.list(); 2.关系映射:一个用户(cust_customer

【SSH三大框架】Hibernate基础第九篇:cascade关联关系的级联操作

这里要说的是Hibernate的关联关系的级联操作,使用cascade属性控制. 依旧用部门和员工举例.多个员工相应一个部门(多对一关联关系) 员工类:Employee.java package cn.itcast.hibernate.domain; public class Employee { private int id; private String name; private Department depart; public int getId() { return id; } pu

Hibernate级联操作解密(inverse和cascade)

总结: Cascade:对级联操作进行限制,有如下几个参数: all : 所有情况下均进行关联操作.  none:所有情况下均不进行关联操作.这是默认值.  save-update:在执行save/update/saveOrUpdate时进行关联操作.  delete:在执行delete时进行关联操作. Inverse:在一对多模型中,只能在一的一方设置,inverse的作用就是在级联发生后,会再次更新子表数据的外键为主表的主键.确保子表外键不会为空. 下面演示一个班级学生的例子(一对多): 班

使用hibernate作为底层,jquery实现级联操作(附带oracle数据库)

原文:使用hibernate作为底层,jquery实现级联操作(附带oracle数据库) 源代码下载地址:http://www.zuidaima.com/share/1564685226675200.htm 为了减轻压力,项目中的hibernate jar包已经删除.请自行增加即可正常运行.若没有jar包请在官方群:南京-木木-11187  或者私信我索要. 备注:数据库在项目根目录的db文件夹下,双击run.bat即可导入.(PS:请用文本文档打开看下用户名和密码是否和你的一致.)如果出现不懂

Hibernate级联操作和加载机制(二) cascade and fetch

上一篇介绍了Hibernate持久化对象时候的级联操作,本篇介绍读取时候的级联操作. 还是用上一篇的例子,一份问卷有多个问题,但是每个问题只能属于一份问卷.我们先看测试用例: @Test public void testReadFromQuestionnaire(){ Session session = sessionFactory.getCurrentSession(); session.beginTransaction(); Questionnaire qn = (Questionnaire