文档章节

mybatis 各种数据库操作的返回值 转

Jian~
 Jian~
发布于 2015/05/27 13:55
字数 333
阅读 30
收藏 0

insert,返回值是:新插入行的主键(primary key);需要包含<selectKey>语句,才会返回主键,否则返回值为null。 需要注意的是  想取到 id直接通过插入的对象取到   返回的值是受影响的行数
update/delete,返回值是:更新或删除的行数;无需指明resultClass;但如果有约束异常而删除失败,只能去捕捉异常。
queryForObject,返回的是:一个实例对象或null;需要包含<select>语句,并且指明resultMap;
queryForList,返回的是:实例对象的列表;需要包含<select>语句,并且指明resultMap;

<typeAlias alias="UnlockTagInfo" type="com.desktop.common.bean.UnlockTagInfo" />
	<resultMap class="UnlockTagInfo" id="UnlockTagInfoResult">
		<result column="id" property="id" jdbcType="INTEGER" />
		<result column="name" property="name" jdbcType="VARCHAR" />
		<result column="description" property="description" jdbcType="VARCHAR" />
		<result column="priority" property="priority" jdbcType="INTEGER" />
	</resultMap>
	<insert id="insertUnlockTagInfo" parameterClass="map">
		<selectKey resultClass="int" keyProperty="id">
			select
			nextval('desktop_unlock_tag_id_seq') as id
		</selectKey>
		insert into
		desktop_unlock_tag(id,name,description,priority)
		values(#id:INTEGER#,#name:VARCHAR#,#description:VARCHAR#,#priority:INTEGER#)
	</insert>
	<update id="updateUnlockTagInfo" parameterClass="map">
		update
		desktop_unlock_tag
		set modify_time=now(),priority=#priority:INTEGER#,
		name=#name:VARCHAR#,description=#description:VARCHAR#
		where
		id=#id:INTEGER#
	</update>
	<delete id="deleteUnlockTagInfo" parameterClass="int">
		delete from
		desktop_unlock_tag
		where id=#value:INTEGER#
	</delete>
	<select id="countUnlockTagInfo" resultClass="int">
		select count(*)
		from
		desktop_unlock_tag
	</select>
	<sql id="selectUnlockTagInfo">
		select
		id,name,description,priority
		from
		desktop_unlock_tag
	</sql>
	<select id="findUnlockTagInfoById" parameterClass="int"
		resultMap="UnlockTagInfoResult">
		<include refid="selectUnlockTagInfo" />
		where id=#id:INTEGER#
	</select>
	<select id="listUnlockTagInfo" parameterClass="map"
		resultMap="UnlockTagInfoResult">
		<include refid="selectUnlockTagInfo" />
		order by
		modify_time desc limit #size:INTEGER#
		offset #start:INTEGER#
	</select>


本文转载自:http://blog.csdn.net/gaojinshan/article/details/24308313

共有 人打赏支持
Jian~
粉丝 1
博文 49
码字总数 11943
作品 0
苏州
私信 提问
MyBatis实战缓存机制设计与原理解析

数据缓存设计结构 一级缓存 Session会话级别的缓存,位于表示一次数据库会话的对象之中,又被称之为 一级缓存是MyBatis内部实现的一个特性,,,一般用户没有定制它的权利 二级缓存 Applicat...

技术小能手
10/24
0
0
终结篇:MyBatis原理深入解析(三)

11 MyBatis一级缓存实现# 11.1 什么是一级缓存? 为什么使用一级缓存?## 每当我们使用MyBatis开启一次和数据库的会话,MyBatis会创建出一个SqlSession对象表示一次数据库会话。 在对数据库的...

猿码道
2016/08/04
0
0
终结篇:MyBatis原理深入解析(一)

1 引言# 本文主要讲解JDBC怎么演变到Mybatis的渐变过程,重点讲解了为什么要将JDBC封装成Mybaits这样一个持久层框架。再而论述Mybatis作为一个数据持久层框架本身有待改进之处。 2 JDBC实现查...

猿码道
2016/08/04
0
0
Mybatis入门例子

Mybatis是轻量级的持久化框架,的确上手非常快. Mybatis大体上的思路就是由一个总的config文件配置全局的信息,比如mysql连接信息等。然后再mapper中指定查询的sql,以及参数和返回值。 在S...

青夜之衫
2017/12/05
0
0
《深入理解mybatis原理》 MyBatis的一级缓存实现详解 及使用注意事项

MyBatis是一个简单,小巧但功能非常强大的ORM开源框架,它的功能强大也体现在它的缓存机制上。MyBatis提供了一级缓存、二级缓存 这两个缓存机制,能够很好地处理和维护缓存,以提高系统的性能...

java梦想家01
2016/01/11
527
1

没有更多内容

加载失败,请刷新页面

加载更多

Confluence 6 快捷键

快捷键图标。 官方的下载地址为:https://atlassianblog.wpengine.com/wp-content/uploads/2018/01/keyboard-shortcuts-infographics.pdf...

honeymose
59分钟前
2
0
Apache限定目录解析PHP,限制user_agent,PHP相关的配置

Apache限定目录解析PHP 配置前访问upload/index.php [root@test-a ~]# curl -x192.168.77.139:80 'www.test.com/upload/index.php'This is upload diretory 配置,/usr/local/apache2.4/......

野雪球
今天
3
0
java.util.Concurrent.Exchanger源码

类图 源码: package java.util.concurrent;import java.util.concurrent.atomic.AtomicInteger;import java.util.concurrent.atomic.AtomicReference;import java.util.concurrent......

狼王黄师傅
今天
6
0
Kubernetes里的secret最基本的用法

Secret解决了密码、token、密钥等敏感数据的配置问题,使用Secret可以避免把这些敏感数据以明文的形式暴露到镜像或者Pod Spec中。 Secret可以以Volume或者环境变量的方式使用。 使用如下命令...

JerryWang_SAP
昨天
5
0
2018-11-20学习笔记

1. python数据类型: 给变量赋值什么样的值,变量就是什么样的类型 给变量赋值整数,变量就是整数类型 给变量赋值字符串,变量就是字符串类型 123 和“123”一样吗? 在python中 单引号 与双...

laoba
昨天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部