mybatis 基础
前言
MyBatis作为一款持久层的框架,从最初的ibatis更名,经过五六年的发展更新,如今已经更新到了3.4.5版本。MyBatis通过简单的xml或注解配置,就能将接口和Java的对象映射成数据库的记录,避免了很多的手动配置,现已被越来越多的开发者使用。
刚开始使用的话,可能会有很多困惑:明明传递了值,为什么传递不到xml中?到底该用resultMap还是用resultType?如果我想返回String、Map、List等等,该如何写?在写了这么多MyBatis代码后,我总结了一下项目中常见的几种,供大家参考,如果想进一步了解,请参考官方文档:http://www.mybatis.org/mybatis-3/zh/index.html
干货图

接口和xml对应图表
高清图:http://img.blog.csdn.net/20170831064012748
干货图描述
在业务逻辑中,最常用的当属查询了,传递的值多样化,需要的返回值样式也不一样,但是等写好了回来再看时,发现也就那几种。
1. 参数类型:String,返回值类型:List<对象>
public List<Student> getStudentByName(@Param(value="name") String name);
<select id="getStudentByName" parameterType="java.lang.String" resultMap="BaseResultMap">
select * from xxx where stu_name = #{name}
</select>
2. 参数类型:Map<String, Object>,返回值类型:List<对象>
public List<Student> getStudents(Map<String, Object> params);
<select id="getStudents" parameterType="java.util.Map" resultMap="BaseResultMap">
select * from xxx where stu_name = #{name}
</select>
3. 参数类型:String,返回值类型:对象
public Student getStudentById(@Param(value="id") String id);
<select id="getStudentById" resultMap="BaseResultMap">
select * from xxx where id = #{id}
</select>
4. 参数类型:String,返回值类型:String
String queryUserIdByThirdParty(@Param("openId") String openId);
<select id="queryUserIdByThirdParty" resultType="java.lang.String">
select user_id from sys_users where open_id=#{openId}
</select>
5. 参数类型:String,返回值类型:List<String>
List<String> getUserIds(@Param("tenantId") String tenantId);
<select id="getUserIds" resultType="java.lang.String">
select id from sys_users where tenant_id = #{tenantId};
</select>
6. 参数类型:String,返回值类型:Map<String, Object>
Map<String, Object> getChargeSum(@Param(value = "uid") String uid);
<select id="getChargeSum" resultType="java.util.Map" parameterType="java.lang.String">
select sum(transaction_amount) as chargeSum from xxx where id = #{uid}
</select>
7. 参数类型:String,返回值类型:List<Map<String, Object>>
List<Map<String,Object>> getReadsNum(@Param(value = "account") String account);
<select id="getReadsNum" resultType="java.util.Map">
select * from xxxx where mw_account = #{account}
</select>
8. 参数类型:String,返回值类型:int
int deleteById(@Param(value = "id") String id, @Param(value = "uid") String uid);
<delete id="deleteById" parameterType="java.lang.String">
delete from xxxx where id = #{id} and create_by = #{uid};
</delete>
9. 参数类型:void,返回值类型:int
int deleteById(@Param(value = "id") String id, @Param(value = "uid") String uid);
<delete id="deleteById">
delete from xxxx where id = #{id} and create_by = #{uid};
</delete>
10. 参数类型:对象,返回值类型:int
int updateStuInfo(StudentInfo studentInfo);
<update id="updateStuInfo" parameterType="xx.xxx.xxxx.StudentInfo">
update xxxx set stu_name = #{stuName}...
where id = #{id}
</update>
说明
1. 接口中的@Param注解指的是 org.apache.ibatis.annotations.Param,使用这个注解就相当于给一个参数起一个别名,在xml中可以直接使用这个别名。如果不使用这个注解,需要保证参数的名称和xml中property配置相同。
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.5</version>
</dependency>
2. 在查询中,parameterType有时是可选的,但是resultMap或者resultType基本上都是需要的。
3. BaseResultMap指的是数据表和对象的映射关系,如:
<resultMap id="BaseResultMap" type="xx.xxx.xxxx.StudentInfo">
<id column="id_" jdbcType="VARCHAR" property="id" />
...
</resultMap>
4. 如果使用IDEA开发工具,可以下载Free MyBatis plugin插件,可以在xml和接口直接进行点击跟踪。
这次没有涉及到批量插入和复杂点继承关系查询,后续会更新。
mybatis 基础的更多相关文章
- myBatis 基础测试 表关联关系配置 集合 测试
myBatis 基础测试 表关联关系配置 集合 测试 测试myelipse项目源码 sql 下载 http://download.csdn.net/detail/liangrui1988/599388 ...
- JAVA之Mybatis基础入门--框架搭建与简单查询
JAVA中,操作数据库有JDBC.hibernate.Mybatis等技术,今天整理了下,来讲一讲下Mybatis.也为自己整理下文档: hibernate是一个完全的ORM框架,是完全面向对象的.但 ...
- MyBatis基础入门《二十》动态SQL(foreach)
MyBatis基础入门<二十>动态SQL(foreach) 1. 迭代一个集合,通常用于in条件 2. 属性 > item > index > collection : ...
- mybatis基础系列(四)——关联查询、延迟加载、一级缓存与二级缓存
关本文是Mybatis基础系列的第四篇文章,点击下面链接可以查看前面的文章: mybatis基础系列(三)——动态sql mybatis基础系列(二)——基础语法.别名.输入映射.输出映射 mybat ...
- mybatis基础系列(三)——动态sql
本文是Mybatis基础系列的第三篇文章,点击下面链接可以查看前面的文章: mybatis基础系列(二)--基础语法.别名.输入映射.输出映射 mybatis基础系列(一)--mybatis入门 动态 ...
- mybatis基础系列(二)——基础语法、别名、输入映射、输出映射
增删改查 mapper根节点及其子节点 mybatis框架需要读取映射文件创建会话工厂,映射文件是以<mapper>作为根节点,在根节点中支持9个元素,分别为insert.update.d ...
- mybatis基础系列(一)——mybatis入门
好久不发博客了,写博文的一个好处是能让心静下来,整理下之前学习过的一些知识一起分享,大神路过~ mybatis简介 MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射. ...
- MyBatis基础入门《十九》动态SQL(set,trim)
MyBatis基础入门<十九>动态SQL(set,trim) 描述: 1. 问题 : 更新用户表数据时,若某个参数为null时,会导致更新错误 2. 分析: 正确结果: 若某个参数为nul ...
- MyBatis基础入门《十八》动态SQL(if-where)
MyBatis基础入门<十八>动态SQL(if-where) 描述: 代码是在<MyBatis基础入门<十七>动态SQL>基础上进行改造的,不再贴所有代码,仅贴改动 ...
- MyBatis基础入门《十七》动态SQL
MyBatis基础入门<十七>动态SQL 描述: >> 完成多条件查询等逻辑实现 >> 用于实现动态SQL的元素主要有: > if > trim > ...
随机推荐
- Python——正则表达式特殊符号及用法
由于正则表达式的内容比较多,所以单独写成一系列文章,主要内容是根据小甲鱼所讲的内容综合一下正则表达式的笔记. 贴上小甲鱼的<Python3 如何优雅地使用正则表达式>系列可观看的博客地址: ...
- Python shutil模块
shutil模块下 copy(复制).rm(删除).move(移动) 常用方法举例. copyfileobj(fsrc, fdst[, length])copyfile(src, dst, *, fo ...
- let和const命令
let命令 1.let用来声明变量,类似于var,但只在代码块内有效. { let a = 1; var b = 2; } console.log(a); //a is not defined con ...
- Python crawler access to web pages the get requests a cookie
Python in the process of accessing the web page,encounter with cookie,so we need to get it. cookie i ...
- UEditor1.4.3.3实现图片上传、删除功能
1.下载ueditor1.4.3.3 UTF-8的版本 2.新建一个项目,在项目中添加UEditor,把下载好的插件都放在ueditor这个文件夹中,在进行一些基本的配置 3.在根目录下新建一个为in ...
- 微信公众号批量爬取java版
最近需要爬取微信公众号的文章信息.在网上找了找发现微信公众号爬取的难点在于公众号文章链接在pc端是打不开的,要用微信的自带浏览器(拿到微信客户端补充的参数,才可以在其它平台打开),这就给爬虫程序造成很 ...
- NB-IoT物联网,来了
日前,深圳移动联合华为公司在深圳市福田.前海及盐田区域部署NB-IoT/LTE融合站点130余个,完成NB-IoT系统关键技术验证和组网技术验证,已初步形成NB-IoT试商用条件.深圳移动后续将在深圳 ...
- 一步步搭建Retrofit+RxJava+MVP网络请求框架(二),个人认为这次封装比较强大了
在前面已经初步封装了一个MVP的网络请求框架,那只是个雏形,还有很多功能不完善,现在进一步进行封装.添加了网络请求时的等待框,retrofit中添加了日志打印拦截器,添加了token拦截器,并且对Da ...
- codeforces 897A Scarborough Fair 暴力签到
codeforces 897A Scarborough Fair 题目链接: http://codeforces.com/problemset/problem/897/A 思路: 暴力大法好 代码: ...
- ngixn配置
nginx 配置入门 之前的nginx配置是对nginx配置文件的具体含义进行讲解,不过对于nginx的新手可能一头雾水. 今天看到个文档不错,翻译过来分享给大家,可以让新手更详细地了解nginx配置 ...