日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

mybaits五:主键的自增

發布時間:2025/6/15 编程问答 18 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mybaits五:主键的自增 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

mysql支持主鍵的自增

? ? ? ? ? useGeneratedKeys=="true"使用自增主鍵獲取主鍵值策略

? ? ? ? ??keyProperty:指定對應的主鍵值,也就是mybatis獲取到主鍵值后,將這個值封裝給java bean的某個屬性。

<!-- parameterType可以省略不寫 --><insert id="addEmploy" parameterType="com.atChina.bean.Employee"useGeneratedKeys="true" keyProperty="id">insert into DEPTTEST(deptno, dname, loc) values(#{deptno}, #{dname}, #{loc})</insert>

Oracle不支持主鍵的自增,但使用序列來模擬自增

? oracle每次插入數據的主鍵是從序列中拿到的值

? oracle有這樣的一個序列

?BEFORE運行順序:?

<!-- parameterType可以省略不寫 --><insert id="addEmploy" parameterType="com.atChina.bean.Employee"><!-- keyProperty: 查出的主鍵值封裝給java bean的某個屬性order="BEFORE": 當前sql在插入sql之前運行AFTER: 當前sql在插入sql之后運行resultType: 查出的數據的返回值類型BEFORE運行順序: 先運行selectKey查詢id的sql,查出id值封裝給javaBean的id屬性再運行插入的sql,就可以取出id屬性對應的值 --><selectKey keyProperty="id" resultType="Integer" order="BEFORE">select SEQU_DEPTTEST.nextval from dual</selectKey>insert into DEPTTEST(id, deptno, dname, loc) values(#{id}, #{deptno}, #{dname}, #{loc})</insert>

AFTER運行順序:?

<insert id="addEmploy" parameterType="com.atChina.bean.Employee"><!-- keyProperty: 查出的主鍵值封裝給java bean的某個屬性order="BEFORE": 當前sql在插入sql之前運行AFTER: 當前sql在插入sql之后運行resultType: 查出的數據的返回值類型AFTER運行順序:先運行插入的sql, 從序列中取出新值作為id再運行selectKey查詢id的sql--><selectKey keyProperty="id" resultType="Integer" order="AFTER">select SEQU_DEPTTEST.currval from dual</selectKey>insert into DEPTTEST(id, deptno, dname, loc) values(SEQU_DEPTTEST.nextval, #{deptno}, #{dname}, #{loc})</insert>

?

總結

以上是生活随笔為你收集整理的mybaits五:主键的自增的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。