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
*/
@Test
public 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
*/
@Test
public 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]]
*