Mysql和Oracle获取自增主键
mysql
<!-- parameterType:參數類型,可以省略,?
?? ?獲取自增主鍵的值:
?? ??? ?mysql支持自增主鍵,自增主鍵值的獲取,mybatis也是利用statement.getGenreatedKeys();
?? ??? ?useGeneratedKeys="true";使用自增主鍵獲取主鍵值策略
?? ??? ?keyProperty;指定對應的主鍵屬性,也就是mybatis獲取到主鍵值以后,將這個值封裝給javaBean的哪個屬性
?? ?-->
?? ?<insert id="addEmp" parameterType="com.atguigu.mybatis.bean.Employee"
?? ??? ?useGeneratedKeys="true" keyProperty="id" databaseId="mysql">
?? ??? ?insert into tbl_employee(last_name,email,gender)?
?? ??? ?values(#{lastName},#{email},#{gender})
?? ?</insert>
Oracle
<!--?
?? ?獲取非自增主鍵的值:
?? ??? ?Oracle不支持自增;Oracle使用序列來模擬自增;
?? ??? ?每次插入的數據的主鍵是從序列中拿到的值;如何獲取到這個值;
?? ? -->
?? ?<insert id="addEmp" databaseId="oracle">
?? ??? ?<!--?
?? ??? ?keyProperty:查出的主鍵值封裝給javaBean的哪個屬性
?? ??? ?order="BEFORE":當前sql在插入sql之前運行
?? ??? ??? ? ? AFTER:當前sql在插入sql之后運行
?? ??? ?resultType:查出的數據的返回值類型
?? ??? ?
?? ??? ?BEFORE運行順序:
?? ??? ??? ?先運行selectKey查詢id的sql;查出id值封裝給javaBean的id屬性
?? ??? ??? ?在運行插入的sql;就可以取出id屬性對應的值
?? ??? ?AFTER運行順序:
?? ??? ??? ?先運行插入的sql(從序列中取出新值作為id);
?? ??? ??? ?再運行selectKey查詢id的sql;
?? ??? ? -->
?? ??? ?<selectKey keyProperty="id" order="BEFORE" resultType="Integer">
?? ??? ??? ?<!-- 編寫查詢主鍵的sql語句 -->
?? ??? ??? ?<!-- BEFORE-->
?? ??? ??? ?select EMPLOYEES_SEQ.nextval from dual?
?? ??? ??? ?<!-- AFTER:
?? ??? ??? ? select EMPLOYEES_SEQ.currval from dual -->
?? ??? ?</selectKey>
總結
以上是生活随笔為你收集整理的Mysql和Oracle获取自增主键的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Mybatis的全局配置文件中的标签
- 下一篇: Mysql可重复读实现原理分析