您的位置:首页 > 编程语言 > Java开发

Spring 主键序列获取 DataFieldMaxValueIncrementer

2016-07-22 10:20 573 查看

Spring 主键序列获取

根据不同的主键产生方式,可能需要配置表名、主键字段名或序列名等信息。下面,我们以Oracle和MySql为例分别讲解使用序列及表字段产生主键值的方式。
  DataFieldMaxValueIncrementer接口定义了3个获取下一个主键值的方法:
  lint nextIntValue():获取下一个主键值,主键数据类型为int;
  llong nextLongValue():获取下一个主键值,主键数据类型为long;
  lString nextStringValue():获取下一个主键值,主键数据类型为String;
 
一般数据库都提供了自增键的功能,如MySql的auto_increment、SqlServerr的identity字段等。Spring允许你在应用层产生主键值,为此定义了org.springframework.jdbc.support.incrementer.DataFieldMaxValueIncrementer接口,提供两种产生主键的方案:第一,通过序列产生主键;第二,通过表产生主键。

 
Oracle:
 
<beanid="incre"class="org.springframework.jdbc.support.incrementer.OracleSequenceMaxValueIncrementer">
<propertyname="incrementerName" value="seq_post_id"/> ①指定序列名
<propertyname="dataSource" ref="dataSource"/> ②设置数据源
</bean>
 
MySQL:
 
<beanid="incre"
class="org.springframework.jdbc.support.incrementer.MySQLMaxValueIncrementer">
<propertyname="incrementerName" value="t_post_id"/> ①设置维护主键的表名
<propertyname="columnName" value="sequence_id"/>②用于生成主键值的列名
<propertyname="cacheSize" value="10"/> ③缓存大小
<propertyname="dataSource" ref="dataSource"/>
</bean>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: