hibernate3学习笔记(十六)|容器映射 - 编程入门网
uot;>11. <generator class="native"/>12. </id>13.14. <property name="name" column="name" type="java.lang.String"/>15.16. <bag name="items" table="item">17. <key column="id"/>18. <element column="name" type="java.lang.String"/>19. </bag>20.21. </class>22.</hibernate-mapping>
测试代码: 1.package com.hb3.pack_13;2.3.import java.io.IOException;4.import java.sql.SQLException;5.import java.util.ArrayList;6. 7.import org.hibernate.Session;8.import org.hibernate.SessionFactory;9.import org.hibernate.Transaction;10.import org.hibernate.cfg.Configuration;11. 12.import com.hb3.pack_12.model.User;13. 14.public class BusinessService {15. 16. public static void main(String[] args) throws IOException, SQLException {17.18. Configuration config = new Configuration().configure();19. SessionFactory sessionFactory = config.buildSessionFactory();20. Session session = sessionFactory.openSession();21. 22.23. User user1 = new User();24. user1.setItems(new ArrayList<String>());25. user1.setName("shenbin");26. user1.addItem("Java Gossip");27. user1.addItem("Java Gossip");28. user1.addItem("Caxxx A80");29.30. User user2 = new User();31. user2.setItems(new ArrayList<String>());32. user2.setName("chenyan");33. user2.addItem("Snoppy world");34.35. Transaction tx = session.beginTransaction();36. session.save(user1);37. session.save(user2);38. tx.commit();39. 40.41. session.close();42. sessionFactory.close();43. }44.} hibernate3学习笔记(十六)|容器映射(7)时间:2011-02-03 csdn博客 沈斌Bag是Hibernate自己提供的集合,他和Set的区别是它允许重复,他和List的区别是他不去管List容器中的順序。 然而,倘若要做下面的更新处理: 1.Session session = sessionFactory.openSession();2.Transaction tx = session.beginTransaction();3.User user = (User) session.load(User.class, new Integer(1));4.user.removeItem("Java Gossip");5.tx.commit();6.session.close(); 运行的SQL文为:
由于Bag集合允许重复,当更新数据时,他无法知道需要更改的是重复数据中的哪比数据,所以采取全部删除后重新写入的方式。 然后,这显然是种没有效率的做法。 幸运的是,Hibernate提供idbag。借由在定义Bag映射时加上"collection-id",让Hibernate能确定需要更改的那条记录从而提高效率。 新建表格: 1.CREATE TABLE user (2. id INT(11) NOT NULL auto_increment PRIMARY KEY,3. name VARCHAR(100) NOT NULL default ''''4.);5.6.CREATE TABLE item (7. cid CHAR(32) NOT NULL,8. id INT(11) NOT NULL,9. name VARCHAR(100) NOT NULL10.); 改写User.hbm.xml: 1.<?xml v |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |