当向数据库中插入一条数据的时候,默认是拿不到自增主键的值的, 须要设置以下两个属性才能够拿到主键值!mysql
设置userGeneratedKeys属性值为true:使用自动增加的主键。使用keyProperty设置把主键值设置给哪个属性sql
1 <insert id="addEmp" parameterType="com.neuedu.mybatis.bean.Employee" useGeneratedKeys="true" keyProperty="id" databaseId="mysql">
2 insert into tbl_employee(last_name,email,gender) 3 values(#{lastName},#{gender},#{email}) 4 </insert>
一、须要在oracle数据库中建立自增序列数据库
create sequence emp_seq
start with 1;mybatis
二、在sql映射文件中配置:oracle
order="BEFORE" :设置selectKey中包含的语句先执行spa
resultType:指定返回类型code
keyProperty:将返回值赋值给指定的列blog
1 <!-- Oracle数据库获取主键自增 -->
2 <insert id="insert" databaseId="oracle">
3 <selectKey keyProperty="id" resultType="int" order="before">
4 select emp_seq.nextval from dual 5 </selectKey>
6 insert into tbl_emp values(#{id},#{lastName},#{gender},#{email}) 7 </insert>