Hibernate_3_客户实例_数据库中自动生成主从表

来源:互联网 发布:stewart mac 编辑:程序博客网 时间:2024/05/22 15:48

1)新建一个客户类:

public class User {private Integer id;private String name;// 属性为集合类型,生命并实例化,实例化后,在其它类中就可以直接调用了private Set<String> addressSet = new HashSet<String>();public Integer getId() {return id;}public Set<String> getAddressSet() {return addressSet;}public void setAddressSet(Set<String> addressSet) {this.addressSet = addressSet;}public void setId(Integer id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}// 重写toString函数public String toString() {return "User [id=" + id + ", name=" + name + ", addressSet="+ addressSet + "]";}}

2)持久层执行的操作:

public class UserDao {/** * save */@Testpublic void save() {Session session = SessionFactoryTools.openSession();Transaction tx = null;try {tx = session.beginTransaction();// 生成对象,设置属性内容并保存User user = new User();user.setName("赵一");user.getAddressSet().add("山科B-12-209");user.getAddressSet().add("山科B-10-115");session.save(user);tx.commit();} catch (RuntimeException e) {tx.rollback();throw e;} finally {session.close();}}/** * getById */@Testpublic void getById() {Session session = SessionFactoryTools.openSession();Transaction tx = null;try {tx = session.beginTransaction();// 获取数据并打印User user = (User) session.get(User.class, 1);System.out.println(user);tx.commit();} catch (RuntimeException e) {tx.rollback();throw e;} finally {session.close();}}}

3)主配置文件与1相同。

4)次要的配置文件:

<?xml version="1.0"?><!DOCTYPE hibernate-mapping PUBLIC        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"><hibernate-mapping package="hibernate_3"><!-- 父类:包括主键和属性 --><class name="User" table="user"><!-- 主键:包块主键的名字、类型和所对应的列的名字,以及主键增长策略 属性:包括名字、类型和所对应的列的名字,以及属性的长度子类:包括子类的名字和子类所对应的表的名字外键的名称 ,外键会自动找到父类的主键并对应       子类中的元素:包括名字、所对应的列的名字        --><id name="id" type="int" column="id"><generator class="native" /></id><property name="name" type="string" column="name" length="20" /><set name="addressSet" table="user_addressSet"><key column="userId"></key><element type="string" column="address"></element></set></class></hibernate-mapping>

运行会自动生成两个表,一个父类表和一个子类表,子类表主要存储集合属性addressSet的内容。

*

上列中也可以使用List来存储子表中的地址:

从表中的内容配置:

<!-- 子表对应的类名称:addressList   子表对应的类名称:user_addressList   子表的外键对应的列名:userId   子表中的索引对应的列名:idx      子表元素:类型String、对应的列名address--><list name="addressList" table="user_addressList"> <key column="userId"></key> <list-index column="idx"></list-index> <element type="string" column="address"></element></list>

客户类中的addressList属性要改为:

private List<String> addressList = new ArrayList<String>();

持久化层中的保存要改为:

User user = new User();user.setName("王二");user.getAddressList().add("山科B-12-209");user.getAddressList().add("山科B-12-301");user.getAddressList().add("山科B-10-115");session.save(user);session.save(user);

其余不变。

*

*

上列中也可以使用Map来存储子表中的地址:

从表种的内容配置:

<!-- 子表对应的类名称:addressMap  子表对应的类名称:user_addressMap  子表的外键对应的类型及列名:String、key_  子表中的索引对应的列名:idx      子表元素:类型String、对应的列名address--><map name="addressMap" table="user_addressMap"><key column="userId"></key><map-key type="string" column="key_"></map-key><element type="string" column="address"></element></map>

客户类中的addressMap属性要改为:

private Map<String, String> addressMap = new HashMap<String, String>();

持久化层中的保存要改为:

User user = new User();user.setName("赵六");user.getAddressMap().put("地址一","山科B-12-209");user.getAddressMap().put("地址二","山科B-12-301");user.getAddressMap().put("地址三","山科B-10-115");session.save(user);

其余不变。

*

*

上列中也可以使用Bag来存储子表中的地址:

从表种的内容配置:

<!-- 子表对应的类名称:addressBag  子表对应的类名称:user_addressBag  子表的外键对应的列名:UserId     子表元素:类型String、对应的列名address--><bag name="addressBag" table="user_addressBag"><key column="userId"></key><element type="string" column="address"></element></bag>

客户类中的addressBag属性要改为:

private List<String> addressBag = new ArrayList<String>();

持久化层中的保存要改为:

User user = new User();user.setName("赵六");user.getAddressBag().add("山科B-12-209");user.getAddressBag().add("山科B-12-301");user.getAddressBag().add("山科B-10-115");user.getAddressBag().add("山科B-10-115");session.save(user);

其余不变。

*

*

<!--   当存储的集合为为排序但可以排序的集合时,可以在次要配置文件中添加order-by属性,在order-by中设置按哪一种属性排序,默认为升序(asc)  排列,设置为desc时为降序排列。--><set name="addressSet" table="user_addressSet" order-by="address desc"><key column="userId"></key><element type="string" column="address"></element></set>

按升序排列的输出:

 addressSet=[山科B-10-115, 山科B-12-209, 山科B-12-301]]

按降序排列的输出:

addressSet=[山科B-12-301, 山科B-12-209, 山科B-10-115]]

*


























2 0