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

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

原文地址:https://www.cnblogs.com/unixshell/p/3416002.html