zoukankan      html  css  js  c++  java
  • hibernate 多对一的情况

    <?xml version="1.0" encoding="GBK"?>
    <!DOCTYPE hibernate-mapping
        PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
    
    <hibernate-mapping package="com.wolfgang.domain">
        <class    name="User"    table="t_user">
        
            <id    name="id" type="integer" column="id">
                <generator class="increment"/>
            </id>
            
            <property name="username" column="username"    type="string"
                not-null="true" length="255" unique="true"/>
            
            <property name="password" column="password"    type="string"
                not-null="true" length="255"/>
    
            <many-to-one name="group" column="groupid" class="Group" cascade="all"/>
    ##注意, name表示model中的名字,column表示字表外键的列名,class表示父表的model类, cascade 表示是否级联操作
    </class> </hibernate-mapping>
    <?xml version="1.0" encoding="GBK"?>
    <!DOCTYPE hibernate-mapping
        PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
    
    <hibernate-mapping package="com.wolfgang.domain">
        <class    name="Group"    table="t_group">
        
            <id    name="id" type="integer" column="id">
                <generator class="increment"/>
            </id>
            
            <property name="groupName" column="groupName"    type="string"
                not-null="true" length="255" unique="true"/>
            
        </class>
    </hibernate-mapping>
    DROP TABLE IF EXISTS `t_user`;
    CREATE TABLE `t_user` (
      `Id` int(11) NOT NULL AUTO_INCREMENT,
      `groupname` varchar(255) DEFAULT NULL,
      `groupid` int(11) DEFAULT NULL,
      `username` varchar(255) NOT NULL DEFAULT '',
      `password` varchar(255) NOT NULL DEFAULT '',
      PRIMARY KEY (`Id`),
      KEY `index_groupid` (`groupid`),
      CONSTRAINT `con_groupid` FOREIGN KEY (`groupid`) REFERENCES `t_group` (`id`)
    ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;
    DROP TABLE IF EXISTS `t_group`;
    CREATE TABLE `t_group` (
      `id` int(11) NOT NULL DEFAULT '0',
      `groupName` varchar(255) DEFAULT NULL,
      PRIMARY KEY (`id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;

    多对一的情况,其实就是在domain类的child类中加上一个parent的属性,

    数据库对应的是child表中加上一个外键引用parent表的列。

    注意的是: 外键的列和子表的列需要类型相识,并且主表的列一定要有作为键才行。

  • 相关阅读:
    多国语言功能设计与实现
    锁标记
    Qt之生成Window资源文件(.rc 文件)
    如何获取本地html文件的标题
    Qt+gsoap调用WebService
    在Qt中使用ActiveX控件
    让notepad.exe的utf8不添加BOM
    Asp.Net生命周期系列四
    C#操作AD及Exchange Server总结
    C#彻底解决Web Browser 跨域读取Iframes内容
  • 原文地址:https://www.cnblogs.com/unixshell/p/3416002.html
Copyright © 2011-2022 走看看