ibatis selectKey

<insert id="insert" parameterClass="A">
       <selectKey keyProperty="uuid" type="pre">
           select seq_sample.nextval from dual
       </selectKey>
       <![CDATA[
        insert into tbl_sample(uuid,name) values (#uuid#,#name#)
       ]]>
</insert>  

加上type="pre"(表示在执行insert之前获取主键)

后台输出sql

在log4j.properties中配置 
log4j.logger.java.sql=DEBUG,console

今天在用ibatis selectKey 生成 oracle sequence 的时候 发现一个问题。
其实就是相为SHIPMENT_HISTORY表加入一个主键sequence id shipmentHistoryId,加入一条记录,然后返回这个sequence id

xml 代码

<insert id="abatorgenerated_insert" parameterClass="cn.hot.delivery.domain.ShipHistory">
    insert into SHIPMENT_HISTORY (SHIPMENT_ID, RECORD_CREATED_DATE, REMARK)
    values (#shipmentId:DECIMAL#,  #recordCreatedDate:DATE#, #remark:VARCHAR#)
    <selectKey keyProperty="shipmentHistoryId" resultClass="java.math.BigDecimal">
      select SHIPMENT_HISTORY_ID_SEQUENCE.nextVal from dual
    <selectKey>
<insert>

并且这段statement是由Abator自动生成的,蛮以为肯定不会出错的 。 但是这个 statement在运行的时候报错了 ,说不能插入 能null数值插入到SHIPMENT_HISTORY表中 ,说明这个selectKey就根本没有发挥出作用 。
查找了一下ibatis的中文文档 ,上面由下面的说明如下 :

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

xml 代码

< !—Oracle SEQUENCE Example -->
<insert id="insertProduct-ORACLE" parameterClass="com.domain.Product">
   <selectKey resultClass="int" keyProperty="id" >
     SELECT STOCKIDSEQUENCE.NEXTVAL AS ID FROM DUAL
<selectKey>
   insert into PRODUCT (PRD_ID,PRD_DESCRIPTION)
   values (#id#,#description#)
<insert>

<insert id="insertProduct-MS-SQL" parameterClass="com.domain.Product">
    insert into PRODUCT (PRD_DESCRIPTION)
    values (#description#)
    <selectKey resultClass="int" keyProperty="id" >
      SELECT @@IDENTITY AS ID
<selectKey>
<insert>

也就是说对于oracle来说,<selectKey>   statement是必须前置的,并且 必须把sequence id放到insert into 句子中,就会没有问题的。按照上面的更改我自己的xml如下,果然没有问题了

xml 代码

<insert id="abatorgenerated_insert" parameterClass="cn.hot.delivery.domain.ShipHistory">
<selectKey keyProperty="shipmentHistoryId" resultClass="java.math.BigDecimal">
           select SHIPMENT_HISTORY_ID_SEQUENCE.nextVal as value  from dual
<selectKey>
   insert into SHIPMENT_HISTORY (SHIPMENT_HESTORY_ID,SHIPMENT_ID, RECORD_CREATED_DATE, REMARK)      value(#shipmentHistoryId:DECIMAL#,#shipmentId:DECIMAL#, #recordCreatedDate:DATE#, #remark:VARCHAR#)
<insert>

所以对于不同的数据库来说 。selectKey>   的用法可能是不一样的,网上的由很多资料的解释是根据不同的数据库的驱动,然后selectKey>   的用法也不一样。但是即使你用Abator来是生成,并且在Abator的配置文件中的

表示这个一个OracleDriver的驱动,但是Abator不会的根据不同的驱动然后生成不同的selectKey> 语句,所以说你如果用到oracle的时候,只能手工的改动这个statement了。

其实也可以用在insert语句中直接调用SEQUENCE.nextVal的方法来生成sequence id,例如

xml 代码

<insert id="abatorgenerated_insert"parameterClass="cn.hot.delivery.domain.ShipHistory">
insert into SHIPMENT_HISTORY (SHIPMENT_HISTORY_ID,SHIPMENT_ID,RECORD_CREATED_DATE, REMARK)
Values
(SHIPMENT_HISTORY_ID_SEQUENCE.nextVal,#shipmentId:DECIMAL#, #recordCreatedDate:DATE#, #remark:VARCHAR#)
<insert>

这个statement是可以生成sequence并且插入记录的,唯一的缺点就是你不能同时通过

Object newKey = getSqlMapClientTemplate().insert(
"SHIPMENT_HISTORY.abatorgenerated_insert", record);

同时得到newKey这个sequence

总之,相对来说,selectKey>还是比较好用的,只要你注意你用的数据库的问题(再说,ibatis也没有屏蔽掉数据库之间的差异)

ibatis selectKey

时间: 2024-10-14 16:04:30

ibatis selectKey的相关文章

ibatis selectKey用法问题

其实就是相为SHIPMENT_HISTORY表加入一个主键sequence id shipmentHistoryId,加入一条记录,然后返回这个sequence id xml 代码 <insert id="abatorgenerated_insert" parameterClass="cn.hot.delivery.domain.ShipHistory"> insert into SHIPMENT_HISTORY (SHIPMENT_ID, RECORD

ibatis selectKey用法注意事项

在我们使用插入数据库时,大部门ID是自增长的,需要返回ID,然后再插入相关的关系表中.但是有时候同样也会抛出问题,比如以下场景: 开始使用int做为ID自增长,返回相关的主键值,但是后来改动,改为String类型,使用UUID赋值,但是在ibatis时,依然保留如下的配置:   <insert id="insertInternet" parameterClass="dmGroupDO" >     INSERT INTO dm_group(id,name

Mybatis/Ibatis,数据库操作的返回值

该问题,我百度了下,根本没发现什么有价值的文章:还是看源代码(详见最后附录)中的注释,最有效了!insert,返回值是:新插入行的主键(primary key):需要包含<selectKey>语句,才会返回主键,否则返回值为null.update/delete,返回值是:更新或删除的行数:无需指明resultClass:但如果有约束异常而删除失败,只能去捕捉异常.queryForObject,返回的是:一个实例对象或null:需要包含<select>语句,并且指明resultMap

iBatis 简单介绍及基础入门

iBATIS一词来源于“internet”和“abatis”的组合,是一个由Clinton Begin在2002年发起的开放源代码项目.于2010年6月16号被谷歌托管,改名为MyBatis.是一个基于SQL映射支持Java和·NET的持久层框架. iBATIS提供的持久层框架包括SQL Maps和Data Access Objects(DAO),同时还提供一个利用这个框架开发的JPetStore实例. 相对Hibernate和ApacheOJB等“一站式”ORM解决方案而言,ibatis 是一

iBatis简单入门教程

iBatis 简介: iBatis 是apache 的一个开源项目,一个O/R Mapping 解决方案,iBatis 最大的特点就是小巧,上手很快.如果不需要太多复杂的功能,iBatis 是能够满足你的要求又足够灵活的最简单的解决方案,现在的iBatis 已经改名为Mybatis 了. 官网为:http://www.mybatis.org/ 搭建iBatis 开发环境: 1 .导入相关的jar 包,ibatis-2.3.0.677.jar .mysql-connector-java-5.1.6

iBatis 入门笔记

iBatis简介 iBatis是一个"半自动"的轻量级O/R Mapping框架. O/R Mapping是指对象与数据库之间的映射,而iBatis就是这样一个映射器,映射器的主要作用是在对象和数据库之间搬运数据,同时保证对象.数据库和映射器之间相互独立. 通过O/R Mapping你将不用再面对那一堆令人厌恶的JDBC代码,为一堆打开连接.关闭连接的代码而眼花头昏. 何为"半自动"?    这里的半自动是与Hibernate这样的O/R Mapping方案对比得出

IBatis增删改查

1.创建Maven项目,项目名称ibatisdemo,目录结构如图所示 2.pom.xml文件中的内容如下 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi=" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">   <m

IBatis学习

(1)建立 SqlMap.config文件 <?xml version="1.0" encoding="utf-8" ?> <sqlMapConfig xmlns="http://ibatis.apache.org/dataMapper" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> <!--<properties resour

iBatis的基本使用

数据库连接信息:db.properties driverClass=com.mysql.jdbc.Driverurl=jdbc:mysql://localhost:3306/ssiusername=rootpassword=123456 主配置文件:sqlMapConfig.xml 1 <?xml version="1.0" encoding="utf-8"?> 2 <!DOCTYPE sqlMapConfig 3 PUBLIC "-//