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

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

  • 相关阅读:
    小程序登录页面
    小程序环境搭建
    js闭包
    作用域和作用域链及预解析
    高阶函数
    在.net core项目中,增加gulp打包任务
    阿里云部署docker-swarm 内网问题
    .net identity scaffold
    c#中对XML反序列化
    c# Reactive Extension中的FromEventPattern和FromEvent
  • 原文地址:https://www.cnblogs.com/unixshell/p/3416002.html
Copyright © 2011-2022 走看看