因为Oracle数据库而言 不能够像SqlServer和MySql一样主键自增
而且MyBatis也没有提供直接的主键自增方法 所以我们自己使用查询语句来实现自增
实现代码:
1 <insert id="Method" parameterType="package.Class" useGeneratedKeys="true" flushCache="true"> 2 <selectKey keyProperty="empno" resultType="String" order="BEFORE"> 3 select max(Primarykey)+1 from table_name 4 </selectKey> 5 insert into emp(Primarykey,column1,column2,column3) values(#{Primarykey},#{column1},#{column2},#{column3}) 6 </insert>
我们在insert插入标签内除了查询语句以外 还添加了selectKey标签 他又以下属性需要必须设置
keyProperty 是指定你持久化类中的主键属性名称
resultType 是指持久化类中的主键属性类型
order 有两个属性 AFTER是指是先执行插入语句 BEFORE是先执行selectKye标签内的语句
select max(表主键列)+每次增长的数量 from 表名