【Ibatis】(七)、自动生成主键

很多数据库支持自动生成主键的数据类型。不过这通常(并不总是)是个私有的特性。SQL Map通过<insert>的子元素<selectKey>来支持自动生成的键值。它同时支持预生成(如Oracle)和后生成两种类型(如MS-SQL Server)。

1. 建表,将id设置为主键,且需加上auto_increment设置为自动增加

create table ibatis_db.t_product(pro_id int(6)

PRIMARY KEYauto_incrementnot null,

pro_descriptionvarchar(150) not null,

pro_price double not null);

2.product_sqlmap.xml中将

Xml代码 收藏代码
  1. <insertid="insertProduct"
  2. parameterClass="product">
  3. <![CDATA[
  4. insertintot_product(prd_id,prd_description,prd_price)
  5. values(#id#,#description#,#price#)
  6. ]]>
  7. </insert>

修改为:

Xml代码 收藏代码
  1. <!--<spanstyle="color:#ff0000;">OracleSEQUENCEExample</span>
  2. -->
  3. <insertid="insertProduct-ORACLE"parameterClass="com.domain.Product">
  4. <selectKeyresultClass="int"keyProperty="id">
  5. SELECTSTOCKIDSEQUENCE.NEXTVALASIDFROMDUAL
  6. </selectKey>
  7. insertintoT_PRODUCT(PRD_ID,PRD_DESCRIPTION)
  8. values(#id#,#description#)
  9. </insert>
  10. <!--<spanstyle="color:#ff0000;">MicrosoftSQLServerIDENTITYColumnExample</span>
  11. -->
  12. <insertid="insertProduct-MS-SQL"parameterClass="com.domain.Product">
  13. insertintoT_PRODUCT(PRD_DESCRIPTION)
  14. values(#description#)
  15. <selectKeyresultClass="int"keyProperty="id">
  16. SELECT@@IDENTITYASID
  17. </selectKey>
  18. </insert>
  19. <!--<spanstyle="color:#ff0000;">MysqlSEQUENCE</span>
  20. -->
  21. <insertid="insertUser-MY-SQL"parameterClass="product">
  22. INSERTINTOT_PRODUCT(pro_description,pro_price)VALUES(#description#,#price#)
  23. <selectKeyresultClass="int"keyProperty="id">
  24. SELECTLAST_INSERT_ID()asid
  25. </selectKey>
  26. </insert><spanstyle="color:#000000;">
  27. </span>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值