Hibernate 表关系描述之OneToOne
在数据库领域中,数据表和数据表之间关系一般可以分为如下几种:
 单对单:比如公民和身份证的关系,一个人只有一张身份证,同时每张身份证也仅仅对应一个人!
 单对多:比如单个客户和订单之间的关系,每个客户可以同时下多张订单!
 多对多:比如学生管理系统中,学生与课程,教师与学生之间的关系!
 上面是简单的说了下数据库表与表之间的关系,那么我们现在要说的是Hibernate,来看看Hibernate中如何使用表与表的关系,首先来看看我数据库中二个示例表user和card分别表示用户和身份证!二个表中分别有二字段,创建表的DDL如下: 
 create table `study`.`card`(
 create table `study`.`card`( `cardid` int default '' not null,--主键
        `cardid` int default '' not null,--主键 `cardnum` int,    --身份证号
       `cardnum` int,    --身份证号 primary key (`cardid`)
        primary key (`cardid`) );
    ); create unique index `PRIMARY` on `study`.`card`(`cardid`);
    create unique index `PRIMARY` on `study`.`card`(`cardid`);
 create table `study`.`user`(
        create table `study`.`user`( `userid` int not null auto_increment,--主键,自动递增
        `userid` int not null auto_increment,--主键,自动递增 `username` varchar(20),--用户名
       `username` varchar(20),--用户名 primary key (`userid`)
        primary key (`userid`) );
    ); create unique index `PRIMARY` on `study`.`user`(`userid`);
    create unique index `PRIMARY` on `study`.`user`(`userid`);
这二张表简单说明人与身份证的关系,熟练点的朋友可能看到我们并没有在card类中为cardid指明外键,而它的外键应该就是user表中的userID,那么这些关系在哪儿声明呢,讲到Hibernate,当然就是在Hibernate中定义了,好了,开始看看如何做:
 首先还是建立一个Project,加载Hibernate,并且由MYSQL,生成映射Bean,具体做方法参见Hibernate 初识(补充)
 ,我们看生成的Card和User类很普通,与先前我们讲到的没什么区别,但现在我们要在这二个Bean中添加属性,Card添加user属性,而User添加card属性,完整代码如下:
 User.java
User.java
 Card.java
Card.java我们现在就可以看到这样用户中有卡,卡也对应用户,一对一!在Bean中体现,当然现在我们已经要有概念,就是仅仅在Bean中这样声明是没用的,我们需要修改类与表的映射文件
 先改User.hbm.xml:内容如下:
 <?xml version="1.0" encoding="GBK"?>
<?xml version="1.0" encoding="GBK"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <!--
<!--  Mapping file autogenerated by MyEclipse - Hibernate Tools
    Mapping file autogenerated by MyEclipse - Hibernate Tools -->
--> <hibernate-mapping>
<hibernate-mapping> <class name="fengyan.hibernate.User" table="user">
    <class name="fengyan.hibernate.User" table="user"> <id name="userid" type="java.lang.Integer">
        <id name="userid" type="java.lang.Integer"> <column name="userid" />
            <column name="userid" /> <generator class="native" /><!-- 主键为自动递增 -->
            <generator class="native" /><!-- 主键为自动递增 --> </id>
        </id> <property name="username" type="java.lang.String">
        <property name="username" type="java.lang.String"> <column name="username" length="20" />
            <column name="username" length="20" /> </property>
        </property> 
         <!--
        <!--  我们添加一个<ont-to-one>节点
            我们添加一个<ont-to-one>节点  里面的属性card    对应的calss
            里面的属性card    对应的calss           cascade="all"一个用户对应一张卡,一张卡对应一个用户,但还是有一个主的,也就是人
            cascade="all"一个用户对应一张卡,一张卡对应一个用户,但还是有一个主的,也就是人 我们先出生人,然后才办卡,所以在这加入cascade由User主控
            我们先出生人,然后才办卡,所以在这加入cascade由User主控                                                             -->
        -->       <one-to-one name="card" class="fengyan.hibernate.Card" cascade="all"></one-to-one>
        <one-to-one name="card" class="fengyan.hibernate.Card" cascade="all"></one-to-one> </class>
    </class> </hibernate-mapping>
</hibernate-mapping>
补充说明,cascade=all,说明当User删除或增加时Card也受影响!
Card.hbm.xml 内容如下:
 <?xml version="1.0" encoding="GBK"?>
<?xml version="1.0" encoding="GBK"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <!--
<!--  Mapping file autogenerated by MyEclipse - Hibernate Tools
    Mapping file autogenerated by MyEclipse - Hibernate Tools -->
--> <hibernate-mapping>
<hibernate-mapping> <class name="fengyan.hibernate.Card" table="card">
    <class name="fengyan.hibernate.Card" table="card"> <id name="cardid" type="java.lang.Integer">
        <id name="cardid" type="java.lang.Integer"> <column name="cardid" />
            <column name="cardid" /> <generator class="foreign"><!-- User是递增,那么卡的编号从哪来? -->
            <generator class="foreign"><!-- User是递增,那么卡的编号从哪来? --> <param name="property">user</param><!--外键为user这个属性来确定-->
                <param name="property">user</param><!--外键为user这个属性来确定--> </generator>
            </generator> </id>
        </id> <property name="cardnum" type="java.lang.Integer">
        <property name="cardnum" type="java.lang.Integer"> <column name="cardnum" />
            <column name="cardnum" /> </property>
        </property> 
         <one-to-one name="user" class="fengyan.hibernate.User"></one-to-one>
        <one-to-one name="user" class="fengyan.hibernate.User"></one-to-one> </class>
    </class> </hibernate-mapping>
</hibernate-mapping>配置完成后,我们来一编写一个DAO类userDAO.java代码如下:
 package fengyan.hibernate;
package fengyan.hibernate;
 import org.hibernate.Session;
import org.hibernate.Session; import org.hibernate.Transaction;
import org.hibernate.Transaction;
 public class UserDAO {
public class UserDAO {
 public void save(User user)
    public void save(User user) {
    { 
         Session session = HibernateSessionFactory.getSession();
        Session session = HibernateSessionFactory.getSession(); Transaction transaction = session.beginTransaction();
        Transaction transaction = session.beginTransaction(); session.save(user);
        session.save(user); transaction.commit();
        transaction.commit(); session.close();
        session.close(); }
    } }
}新建一个Servlet处理代码如下:
 public void doPost(HttpServletRequest request, HttpServletResponse response)
    public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            throws ServletException, IOException {
 User user = new User();
        User user = new User(); user.setUsername("fengyan");//设置用户名
        user.setUsername("fengyan");//设置用户名 Card card = new Card();
        Card card = new Card(); card.setCardnum(420983);//设置身份证号
        card.setCardnum(420983);//设置身份证号 user.setCard(card);
        user.setCard(card); card.setUser(user);
        card.setUser(user); UserDAO ua = new UserDAO();
        UserDAO ua = new UserDAO(); ua.save(user);//这样在添加用户的时候会自动添加一张卡
        ua.save(user);//这样在添加用户的时候会自动添加一张卡 }
    }最后JSP代码:
 <body>
  <body> This is my JSP page. <br>
    This is my JSP page. <br> <a href="servlet/addUser">add user</a>
    <a href="servlet/addUser">add user</a> </body>
  </body>当我们运行的时候,会发现User表中新增了一条记录
同时Card表中也新增了一条记录,但我们在doPost()方法中仅仅是save(user),而并没有save(card),为什么card也会添加进去,这就是我们在配置文件中写的表关系作用!
 
                    
                     
                    
                 
                    
                
 
     
                
            
         
 
         浙公网安备 33010602011771号
浙公网安备 33010602011771号