`
guyongpeng
  • 浏览: 62184 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

利用ibatis在插入记录时同时得到自增长的键值方法

阅读更多
在SQL Server数据库中,采用自增长的字段作为主键,在插入一条记录时有时需要同时得到自增长的id。一般的方式是先执行insert语句,然后根据该insert的数据唯一特征(唯一键)检索到该数据,得到id。这个方法首先不方便,其次对于该数据没有唯一特征的情况甚至都不可行。ibatis提供了简单的解决办法。

表结构为:
CREATE TABLE [TaskDeliveryURL] (
	[urlId] [int] IDENTITY (1, 1) NOT NULL ,
	[urlName] [nvarchar] (511) ,
	[urlLink] [nvarchar] (511) ,
	PRIMARY KEY  CLUSTERED ([urlId])  ON [PRIMARY] 
)

model为:
package com.ccg.ciic.proxy.domain;

public class TaskDeliveryUrl {
	private String urlName;
	private String urlLink;
	private long urlId;
	
	public long getUrlId() {
		return urlId;
	}
	public void setUrlId(long urlId) {
		this.urlId = urlId;
	}
	public String getUrlLink() {
		return urlLink;
	}
	public void setUrlLink(String urlLink) {
		this.urlLink = urlLink;
	}
	public String getUrlName() {
		return urlName;
	}
	public void setUrlName(String urlName) {
		this.urlName = urlName;
	}
}

ibatis的映射文件为:
<sqlMap>    
    <insert id="insert" parameterClass="com.ccg.ciic.proxy.domain.TaskDeliveryUrl">
        insert into TaskDeliveryURL(urlName, urlLink) values(#urlName#,#urlLink#)
        <selectKey resultClass="long" keyProperty="urlId" >  
			SELECT @@IDENTITY AS urlId
		</selectKey>
    </insert>
</sqlMap>


这样在将一个TaskDeliveryUrl对象的urlName和urlLink属性注入到映射文件,执行insert操作后,自生成的urlId同时被注入到该TaskDeliveryUrl对象的urlId属性中。
分享到:
评论

相关推荐

    08_ibatis教程_sql主键生成方式.zip

    1. **手工指定主键**:这是最基础的方式,开发人员在插入数据时手动为新记录生成主键值。适用于主键是自增整数或由业务逻辑决定的情况。 2. **序列/序列化**:在Oracle等数据库中,可以创建序列来生成唯一的主键值...

    08_传智播客ibatis教程_sql主键生成方式

    5. **手动指定**:在某些情况下,主键可能由业务逻辑决定,例如用户ID等,此时可在插入数据时直接提供主键值。 了解了这些主键生成策略后,开发者可以根据实际项目需求选择合适的方法。在Ibatis的映射文件中,`...

    iBatis_SqlMap的配置总结[1]

    - **后获取主键**:对于自动增长的主键,如MySQL,`&lt;selectKey&gt;`可以在插入语句之后配置,利用`LAST_INSERT_ID()`获取自增主键。 5. **SQL参数(ParameterClass)**: - 插入操作:`parameterClass`指定传入参数...

    ibatis PPT

    在插入数据后,这个标签会执行一个单独的 SELECT 语句来获取新生成的主键值,并将其绑定到 Java 对象的相应属性上。 **优点** iBatis 的优点包括: 1. **灵活性**:SQL 可以直接编写,不受 ORM 框架的限制,能充分...

    Ibatis入门教程

    注意在定义存储过程时需要使用特定的分隔符(例如`$$`),以避免语法冲突。 3. **创建实体类**: - 实体类`User`包含了`id`、`userName`和`email`三个属性,以及对应的getter和setter方法。同时,为了方便调试,还...

    mybatis insert返回主键代码实例

    在使用 MyBatis 进行数据插入时,需要使用 `selectKey` 元素来获取插入后的主键值。`selectKey` 元素可以在插入语句之前或之后执行,具体的实现方法取决于所使用的数据库系统。 对于 Oracle 数据库,使用 `select...

    mybatis文档

    - MySQL:利用自增长特性,通过 SQL 语句 `SELECT LAST_INSERT_ID()` 获取最后插入行的 ID。 #### 7. 关联关系处理 - **处理方式**:支持多种关联查询方式,包括连接查询和两次查询方式。 - 一对多:使用连接...

Global site tag (gtag.js) - Google Analytics