<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="com.sasa.domain"> <class name="Category" table="category"> <id name="id" column="id"> <generator class="native"></generator> </id> <property name="c_name"></property> <property name="descr"></property> <property name="create_tm"></property> <!-- name属性:集合属性名 column属性: 外键列名 class属性: 与我关联的对象完整类名 --> <!-- 级联操作: cascade save-update: 级联保存更新 delete:级联删除 all:save-update+delete 级联操作: 简化操作.目的就是为了少些两行代码. --> <!-- inverse属性: 配置关系是否维护. true: customer不维护关系 false(默认值): customer维护关系 inverse属性: 性能优化.提高关系维护的性能. 原则: 无论怎么放弃,总有一方必须要维护关系. 一对多关系中: 一的一方放弃.也只能一的一方放弃.多的一方不能放弃. --> <set name="products" cascade="save-update" inverse="true"> <key column="category_id"></key> <one-to-many class="Product"/> </set> </class> </hibernate-mapping>
@Test //新增类别和产品 public void addCategorysCascade(){ Session session = HibernateUtils.getCurrentSession(); Transaction tran = session.beginTransaction(); //======================================== Category category = new Category(); category.setC_name("电子产品"); category.setDescr("电子产品1"); Product p1 = new Product(); p1.setPname("手机"); p1.setPrice(100.00); Product p2 = new Product(); p2.setPname("电子手表"); p2.setPrice(90.00); //一对多 category.getProducts().add(p1); category.getProducts().add(p2); //多对一 p1.setCategory(category); p2.setCategory(category); session.save(category); //========================================== tran.commit(); session.close(); }
原文地址:https://www.cnblogs.com/SasaL/p/11671077.html
时间: 2024-10-12 10:08:53