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
- Hibernate_3_客户实例_数据库中自动生成主从表
- 获得数据库自动生成的主键实例:
- 数据库表自动生成
- Hibernate中利用配置文件(hbm)自动生成数据库表
- Hibernate中自动生成数据库表的两种方式
- Hibernate中自动生成数据库表的两种方式
- hibernate自动生成数据库表
- Hibernate自动生成数据库表
- hibernate 自动生成数据库表
- 【Hibernate】自动生成数据库表
- Java中数据库自动分页完整实例
- SQL 数据库中如何自动生成订单号
- perl客户需求设置自动生成
- 以实例说明如何使用C#从数据库中提取数据,按要求自动生成定制的Excel表格
- 以实例说明如何使用C#从数据库中提取数据,按要求自动生成定制的Excel表格
- 以实例说明如何使用C#从数据库中提取数据,按要求自动生成定制的Excel表格?
- hibernate中关于数据库方言导致不能自动生成数据库表的问题
- 重点介绍如何在安装包中自动为客户创建数据库
- NSFileHandle 类 不能创建文件
- 安装MongoDB
- [leetcode 21] Remove Nth Node From End of List
- 协议,层次,接口
- 输入密码回显星号 -- C语言
- Hibernate_3_客户实例_数据库中自动生成主从表
- struts2自定义类型转换器
- hdu 4915 Parenthese sequence(高效)
- 重装Ubuntu 保留/home分区中的数据
- java中内部类的创建四种情况,三种方式,及内部数据访问权限
- 深拷贝 和 浅拷贝
- 【java】Integer == Integer?
- Codeforce 22B Bargaining Table
- log4cplus 日志应用