用ssh框架做了个注册页面,插入时tomcat总是提示插入的id值为空,可是检查action,form等id值的确是传过来了啊,很郁闷,debug了很久,发现时hibernate的Generator属性class值设置的不对,一开始选择的是native,修改为assigned就可以正常插入了。下面总结一下Hibernate的generator属性的意思。
Hibernate的Generator属性有7种class。
1、identity:用于MySql数据库。特点:递增
< id name="id" column="id">
< generator class="identity"/>< /id>
注:对于MySql数据库使用递增序列时需要在建表时对主键指定为auto_increment属性。
2、sequence:用于Oracle数据库
< id name="id" column="id">
< generator class="sequence">
< param name="sequence">序列名< /param>< /generator>< /id>
3、native:跨数据库时使用,由底层方言产生。
Default.sequence为hibernate_sequence
< id name="id" column="id">< generator class="native"/>< /id>
注:使用native时Hibernate默认会去查找Oracle中的hibernate_sequence序列。
如果Oracle中没有该序列,连Oracle数据库时会报错。
4、hilo:通过高低位合成id,先建表hi_value,再建列next_value。必须要有初始值。
< id name="id" column="id">
< generator class="hilo">
< param name="table">high_val< /param>
< param name="column">nextval< /param>
< param name="max_lo">5< /param>< /generator>< /id>
5、sequencehilo:同过高低位合成id,建一个sequence序列,不用建表。
< id name="id" column="id">
< generator class="hilo">
< param name="sequence">high_val_seq< /param>
< param name="max_lo">5< /param>< /generator>< /id>
6、assigned:用户自定义id;
< id name="id" column="id">
< generator class="assigned"/>
< /id>
7、foreign:用于一对一关系共享主健时,两id值一样。
此外还发现一个问题,就是插入的数据虽然提示插入成功,但是数据库却没有此条记录。原来使用hibernate的save方法保存记录时并没有提交到数据库,必须先声明事务,在save方法完成后,commit()就可以了。示例代码如下: