创建 db_iteam表
create table db_iteam(
id int identity not null,
iteamNum"char(10) not null,
paId int null,
primary key ("id")
)
go
/*************/
创建db_user表
create table db_user (
id int identity not null,
name char(10) not null,
iteamId int null,
primary key ("id")
)
/***********************/
创建db_passport
create table db_passport(
"id" int not null, //主键关联与db_user
"number" char(10) not null,
primary key ("id")
)
go
*******************
vo:
*******************
package wsq.vo;
import java.util.HashSet;
import java.util.Set;
public class DbIteam implements java.io.Serializable {
private Integer id;
private String iteamNum;
private DbIteam subIteam;
private Set subIteams=new HashSet();
private Set users=new HashSet();
public Set getUsers() {
return users;
}
public void setUsers(Set users) {
this.users = users;
}
public DbIteam() {
}
public DbIteam(String iteamNum) {
this.iteamNum = iteamNum;
}
public Integer getId() {
return this.id;
}
public void setId(Integer id) {
this.id = id;
}
public String getIteamNum() {
return this.iteamNum;
}
public void setIteamNum(String iteamNum) {
this.iteamNum = iteamNum;
}
public DbIteam getSubIteam() {
return subIteam;
}
public void setSubIteam(DbIteam subIteam) {
this.subIteam = subIteam;
}
public Set getSubIteams() {
return subIteams;
}
public void setSubIteams(Set subIteams) {
this.subIteams = subIteams;
}
}
******************
package wsq.vo;
public class DbUser implements java.io.Serializable {
private Integer id;
private String name;
private DbIteam dbIteam;
private DbPassport dbPassport;
public DbPassport getDbPassport() {
return dbPassport;
}
public void setDbPassport(DbPassport dbPassport) {
this.dbPassport = dbPassport;
}
public DbUser() {
}
public DbUser(String name) {
this.name = name;
}
public Integer getId() {
return this.id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return this.name;
}
public void setName(String name) {
this.name = name;
}
public String toString()
{
return name+" 测试!";
}
public DbIteam getDbIteam() {
return dbIteam;
}
public void setDbIteam(DbIteam dbIteam) {
this.dbIteam = dbIteam;
}
}
/**********************************/
package wsq.vo;
public class DbPassport implements java.io.Serializable {
private Integer id;
private String number;
private DbUser dbUser;
public DbUser getDbUser() {
return dbUser;
}
public void setDbUser(DbUser dbUser) {
this.dbUser = dbUser;
}
public DbPassport() {
}
public DbPassport(String number) {
this.number = number;
}
public Integer getId() {
return this.id;
}
public void setId(Integer id) {
this.id = id;
}
public String getNumber() {
return this.number;
}
public void setNumber(String number) {
this.number = number;
}
}
/******************************/
配置DbIteam.hbm.xml
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!--
Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
<class name="wsq.vo.DbIteam" table="db_iteam" schema="dbo"
catalog="dbs" >
<id name="id" type="java.lang.Integer">
<column name="id" />
<generator class="native" />
</id>
<property name="iteamNum" type="java.lang.String">
<column name="iteamNum" length="10" not-null="true" />
</property>
<many-to-one name="subIteam" class="wsq.vo.DbIteam" column="paId" />
<set name="users" cascade="all" table="db_user" lazy="true" batch-size="5">
<key column="iteamId"></key>
<one-to-many class="wsq.vo.DbUser" />
</set>
<set name="subIteams" cascade="all" table="db_iteam" lazy="true" batch-size="5">
<key column="paId"></key>
<one-to-many class="wsq.vo.DbIteam" />
</set>
</class>
</hibernate-mapping>
配置DbUser.hbm.xml
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!--
Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
<class name="wsq.vo.DbUser" table="db_user" schema="dbo" catalog="dbs">
<id name="id" type="java.lang.Integer">
<column name="id" />
<generator class="native" />
</id>
<property name="name" type="java.lang.String">
<column name="name" length="10" not-null="true" />
</property>
<many-to-one name="dbIteam" class="wsq.vo.DbIteam" column="iteamId" outer-join="true" ></many-to-one>
<one-to-one name="dbPassport" class="wsq.vo.DbPassport" cascade="all" ></one-to-one>
</class>
</hibernate-mapping>
配置DbPassport.hbm.xml
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!--
Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
<class name="wsq.vo.DbPassport" table="db_passport" schema="dbo"
catalog="dbs">
<id name="id" type="java.lang.Integer">
<column name="id" />
<generator class="foreign" >
<param name="property">dbUser</param>
</generator>
</id>
<property name="number" type="java.lang.String">
<column name="number" length="10" not-null="true" />
</property>
<one-to-one name="dbUser" class="wsq.vo.DbUser" constrained="true"></one-to-one>
</class>
</hibernate-mapping>
/*******************
测试类
package wsq.vo;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.hibernate.Transaction;
public class Test {
private static final Log log = LogFactory.getLog(Test.class);
Test() {
}
public static void main(String[] args) {
BaseHibernateDAO basedao = new BaseHibernateDAO( );
DbIteamDAO iteamDAO = new DbIteamDAO( );
DbUserDAO userDAO = new DbUserDAO( );
DbIteam iteam = new DbIteam( );
DbIteam iteam3 = new DbIteam( );
DbUser user = new DbUser( );
DbPassport ps = new DbPassport( );
Transaction tx = basedao.getSession( ).beginTransaction( );
iteam.setIteamNum("2");
iteam.setSubIteam(iteamDAO.findById(16)); //iteamDAO.findById(16)找到的是一级 此处添加是2级
iteam3.setIteamNum("3");
iteam3.setSubIteam(iteam);//3级
user.setName("djg");
user.setDbIteam(iteam3);
ps.setNumber("48");
user.setDbPassport(ps);
ps.setDbUser(user);
// iteamDAO.delete(iteamDAO.findById(23));
iteamDAO.save(iteam);
iteamDAO.save(iteam3);
userDAO.save(user);
log.info("ok!!!!!! !!ok!!! ok! 111111111111111111 !! !");
tx.commit( );
}
}
posted on 2007-09-02 10:21
Crying 阅读(1104)
评论(0) 编辑 收藏 所属分类:
hibernate