• 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表的列。

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

  • 相关阅读:
    配置高并发jdbc连接池
    java中的sleep()和wait()的区别
    程序员必知的8大排序(三)-------冒泡排序,快速排序(java实现)
    转HashMap Hashtable区别
    chrome 常用快捷操作
    sublime Text 常用操作
    flash 右键菜单隐藏与修改
    As3.0 视频缓冲、下载总结
    flash cs6 更新到Flash player15.0 及Air 更新方法
    As3.0 Interface 与类的使用
  • 原文地址:https://www.cnblogs.com/unixshell/p/3416002.html
Copyright © 2020-2023  润新知