У меня есть этот составной идентификатор:
<composite-id class="Entities.PackageId" name="id">
<key-property name="id" type="int">
<column name="id"/>
</key-property>
<key-property name="idProduct" type="int">
<column name="idProduct"/>
</key-property>
</composite-id>
На самом деле я хотел бы использовать автоинкремент в идентификаторах пакетов и продуктов.Но, похоже, я не могу этого сделать.
Итак, мне нужно сгенерировать один идентификатор для пакета (у продукта уже есть ключ автоинкремента), поэтому мой идентификатор - это максимальное значение из package.id + 1, поэтомутаким образом, у меня есть новый идентификатор для моей посылки.
Есть идеи, кто это делает?
С уважением, Вальтер Энрике.
-
DDL:
DROP TABLE IF EXISTS `Product`;
CREATE TABLE `Product` (
`id` int(11) NOT NULL,
`name` varchar(150) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
DROP TABLE IF EXISTS `package`;
CREATE TABLE `package` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`idProduct` int(11) NOT NULL,
`quantity` int(11) NOT NULL,
`mode` char(1) NOT NULL,
`unity` varchar(25) NOT NULL,
`description` varchar(150) NOT NULL,
`email` varchar(50) NOT NULL,
PRIMARY KEY (`id`,`idProduct`),
KEY `email` (`email`),
KEY `idProduct` (`idProduct`),
CONSTRAINT `package_ibfk_1` FOREIGN KEY (`email`) REFERENCES `usuario` (`email`),
CONSTRAINT `package_ibfk_2` FOREIGN KEY (`idProduct`) REFERENCES `Product` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=14 DEFAULT CHARSET=latin1;
DROP TABLE IF EXISTS `user`;
CREATE TABLE `user` (
`name` varchar(50) NOT NULL,
`lastname` varchar(100) NOT NULL,
`gender` varchar(9) NOT NULL,
`birthday` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
`email` varchar(50) NOT NULL,
`password` varchar(50) NOT NULL,
`street` varchar(100) DEFAULT NULL,
`number` int(11) DEFAULT NULL,
`complement` varchar(100) DEFAULT NULL,
`city` varchar(100) DEFAULT NULL,
`state` varchar(100) DEFAULT NULL,
`country` varchar(100) DEFAULT NULL,
`image` varchar(100) DEFAULT NULL,
`telephone` int(12) DEFAULT NULL,
`cellphone` int(12) DEFAULT NULL,
`lat` double DEFAULT NULL,
`long` double DEFAULT NULL,
PRIMARY KEY (`email`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
Отображение .xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- Generated 25/02/2011 15:56:00 by Hibernate Tools 3.2.1.GA -->
<hibernate-mapping>
<class catalog="p2p" name="Entities.Package" table="Package">
<composite-id class="Entities.PackageId" name="id">
<key-property name="id" type="int">
<column name="id"/>
</key-property>
<key-property name="idProduct" type="int">
<column name="idProduct"/>
</key-property>
</composite-id>
<many-to-one class="Entities.User" fetch="select" name="User">
<column length="50" name="email" not-null="true"/>
</many-to-one>
<many-to-one class="Entities.Product" fetch="select" insert="false" name="Product" update="false">
<column name="idProduct" not-null="true"/>
</many-to-one>
<property name="quantity" type="int">
<column name="quantity" not-null="true"/>
</property>
<property name="mode" type="char">
<column length="1" name="mode" not-null="true"/>
</property>
<property name="unity" type="string">
<column length="25" name="unity" not-null="true"/>
</property>
<property name="description" type="string">
<column length="150" name="description" not-null="true"/>
</property>
</class>
</hibernate-mapping>