189 8069 5689

hibernate一对多关系映射-创新互联

在关系中,或多或少的表之间有复杂的关联关系

创新互联建站的客户来自各行各业,为了共同目标,我们在工作上密切配合,从创业型小企业到企事业单位,感谢他们对我们的要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。专业领域包括做网站、成都做网站、电商网站开发、微信营销、系统平台开发。

这里测试 一对多 关联关系的配置

  1. 开发步骤就不多说了。直接看一个示例。

users 用户 和  shop商品订单表

分析:一个用户可以有多个商品订单,一个订单只属于一个用户。

这样就构成了一对多的关联关系。

这里用的是oracle 数据库

users 和 shop 数据库表

create table users( id number(7) primary key,   name nvarchar2(20),   pass nvarchar2(20),   address nvarchar2(50) ) create table shop( id number(7) primary key,   price number(7), sh_name nvarchar2(50),   us_id references users(id) )

2.users 实体

package com.hib.entity; import java.util.HashSet; import java.util.Set; public class Users { private Integer id; private String name; private String pass; private String address; private Set shop = new HashSet(); public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getPass() { return pass; } public void setPass(String pass) { this.pass = pass; } public String getAddress() { return address; } public void setAddress(String address) { this.address = address; } public Set getShop() { return shop; } public void setShop(Set shop) { this.shop = shop; } public Users(Integer id, String name, String pass, String address) { super(); this.id = id; this.name = name; this.pass = pass; this.address = address; } public Users() { super(); } @Override public String toString() { return "Users [id=" + id + ", name=" + name + ", pass=" + pass + ", address=" + address + "]"; } }

shop 实体

package com.hib.entity; public class Shop { private Integer id; private Integer price; private String sh_name; private Users users; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getSh_name() { return sh_name; } public void setSh_name(String sh_name) { this.sh_name = sh_name; } public Integer getPrice() { return price; } public void setPrice(Integer price) { this.price = price; } public Users getUsers() { return users; } public void setUsers(Users users) { this.users = users; } public Shop(Integer id, String sh_name, Integer price) { super(); this.id = id; this.sh_name = sh_name; this.price = price; } public Shop() { super(); } @Override public String toString() { return "Shop [id=" + id + ", sh_name=" + sh_name + ", price=" + price + "]"; } }

3.shop.hbm.xml映射文件配置

4. 不要忘记注册。

             oracle.jdbc.OracleDriver         ssh         ssh         jdbc:oracle:thin:@127.0.0.1:1521:xe                           org.hibernate.dialect.Oracle10gDialect                  true                  true                 thread                                

5.测试  级联插入测试

@Test public void insert(){ Session session = HibUtil.getSession(); Transaction tx = session.beginTransaction(); Users users = new Users(null, "苦力强", "kuliqiang", "zg"); Shop shop = new Shop(null, "橙子", 2800); users.getShop().add(shop); shop.setUsers(users); session.save(users); tx.commit(); }

记得要设置级联关系。

测试  查询

@Test public void query(){ Session session = HibUtil.getSession(); Transaction tx = session.beginTransaction(); Users users = (Users)session.get(Users.class, 1); for (Shop shop : users.getShop()) { System.out.println(shop); } System.out.println(users); tx.commit(); }

更新和删除就不测试了,更新先查询出来,再修改值,然后更新就可以了。

删除直接查询出来,删除就可以了。

如果是单向的1对多 上面的可以修改为

  1. users 实体不改变

  2. shop 中的 users去掉

  3. 配置文件中 去掉下面这段配置

4. 配置文件中 inverse="true" 去掉,告诉主表,来维护从表

其他的还是一样操作。

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


分享文章:hibernate一对多关系映射-创新互联
网站路径:http://cdxtjz.cn/article/gohhs.html

其他资讯