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

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]]

*


























  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值