Un, un à plusieurs | plusieurs à un
Expression de la relation
Expression dans le tableau
Expression dans l'entité
Expression dans les métadonnées orm
One-to -many
<!-- 集合,一对多关系,在配置文件中配置 --><!-- name属性:集合属性名 column属性: 外键列名 class属性: 与我关联的对象完整类名 --><set name="linkMens" inverse="true" cascade="delete" ><key column="lkm_cust_id" ></key><one-to-many class="LinkMan" /></set>
Plusieurs-à-un
<!-- 多对一 --><!-- name属性:引用属性名 column属性: 外键列名 class属性: 与我关联的对象完整类名 --><many-to-one name="customer" column="lkm_cust_id" class="Customer" ></many-to-one>
Opération
Attributs associés à l'opération
//3操作Customer c = new Customer(); c.setCust_name("传智播客"); LinkMan lm1 = new LinkMan(); lm1.setLkm_name("黎活明"); LinkMan lm2 = new LinkMan(); lm2.setLkm_name("刘悦东"); //表达一对多,客户下有多个联系人 c.getLinkMens().add(lm1); c.getLinkMens().add(lm2); //表达对对对,联系人属于哪个客户 lm1.setCustomer(c); lm2.setCustomer(c); session.save(c); session.save(lm1); session.save(lm2);
3. Opération avancée
Opération en cascade
<span style="color: #008000"><!--</span><span style="color: #008000"> 级联操作: cascade save-update: 级联保存更新 delete:级联删除 all:save-update+delete 级联操作: 简化操作.目的就是为了少些两行代码. </span><span style="color: #008000">--><br></span>
<set name="linkMens" inverse="true" cascade="delete" ><key column="lkm_cust_id" ></key><one-to-many class="LinkMan" /></set>
Conclusion : Fonctionnement simplifié. Il faut utiliser la sauvegarde-mise à jour, la suppression n'est pas recommandée
Maintien de la relation
Lors de l'enregistrement, les deux parties maintiendront la relation de clé étrangère. La relation est maintenue deux fois, ce qui est redondant. Les déclarations de maintien de relation redondantes sont évidemment du côté du client qui maintient la relation
<!-- inverse属性: 配置关系是否维护. true: customer不维护关系 false(默认值): customer维护关系 inverse属性: 性能优化.提高关系维护的性能. 原则: 无论怎么放弃,总有一方必须要维护关系. 一对多关系中: 一的一方放弃.也只能一的一方放弃.多的一方不能放弃. --><set name="linkMens" inverse="true" cascade="delete" ><key column="lkm_cust_id" ></key><one-to-many class="LinkMan" /></set>
2. Plusieurs à plusieurs
1. >Expressions dans les tableaux
Objets
>
2. Opération<!-- 多对多关系表达 --><!-- name: 集合属性名 table: 配置中间表名 key |-column:外键,别人引用"我"的外键列名 class: 我与哪个类是多对多关系 column:外键.我引用比人的外键列名 --> <!-- cascade级联操作: save-update: 级联保存更新 delete:级联删除 all:级联保存更新+级联删除 结论: cascade简化代码书写.该属性使不使用无所谓. 建议要用只用save-update. 如果使用delete操作太过危险.尤其在多对多中.不建议使用. --><set name="roles" table="sys_user_role" cascade="save-update" ><key column="user_id" ></key><many-to-many class="Role" column="role_id" ></many-to-many></set>
3. Attribut inverse
//3> 用户表达关系 u1.getRoles().add(r1); u1.getRoles().add(r2); u2.getRoles().add(r1); u2.getRoles().add(r2); //4> 角色表达关系 r1.getUsers().add(u1); r1.getUsers().add(u2); r2.getUsers().add(u1); r2.getUsers().add(u2); //5> 调用Save方法一次保存 session.save(u1); session.save(u2); session.save(r1); session.save(r2);
<!-- 使用inverse属性 true: 放弃维护外键关系 false(默认值):维护关系 结论: 将来在开发中,如果遇到多对多关系.一定要选择一方放弃维护关系. 一般谁来放弃要看业务方向. 例如录入员工时,需要为员工指定所属角色. 那么业务方向就是由员工维护角色. 角色不需要维护与员工关系.角色放弃维护 --> <set name="users" table="sys_user_role" inverse="true" ><key column="role_id" ></key><many-to-many class="User" column="user_id" ></many-to-many></set>
<!-- cascade级联操作: save-update: 级联保存更新 delete:级联删除 all:级联保存更新+级联删除 结论: cascade简化代码书写.该属性使不使用无所谓. 建议要用只用save-update. 如果使用delete操作太过危险.尤其在多对多中.不建议使用. --><set name="roles" table="sys_user_role" cascade="save-update" ><key column="user_id" ></key><many-to-many class="Role" column="role_id" ></many-to-many></set>
Servlet :
service :
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {//1> 获得参数并封装LinkMan对象中LinkMan lm = new LinkMan();try { BeanUtils.populate(lm, request.getParameterMap()); } catch (IllegalAccessException e) { e.printStackTrace(); } catch (InvocationTargetException e) { e.printStackTrace(); }//2> 调用Service保存LinkMan对象 lms .save(lm);//3> 重定向到LinkMan的列表(404)response.sendRedirect(request.getContextPath()+"/ListLinkManServlet"); }
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!