MyBatis注解及动态Sql
一、注解实现MyBatis配置
java注解是在jdk1.5版本之后开始加入的,不得不说注解对于我们开发人员来说是个很方便的东西,实现起来也非常的简单,下边我们说一下在MyBatis中使用注解来替换Mapper配置文件。
package com.lhf.dao; import com.lhf.entity.User;
import org.apache.ibatis.annotations.Delete;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.annotations.Update; import java.util.List; public interface UserDao {
@Select("select * from user")
List<User> getAll();
@Delete("delete from user where id=#{id}")
int del(int id);
@Insert("insert into user values(default,#{name},#{pwd})")
int add(User user);
@Update("update user set name=#{name},pwd=#{pwd} where id=#{id}")
int modify(User user);
}
删除UserDaoMaper的xml文件,在dao层使用注解(select、delete、insert、update)来实现数据库的简单操作,这个效果与Xml文件的效果是一致的。上一篇中有介绍xml文件的配置
一定会有人问,这里方法内的参数一般都是一个,那如果是两个以及以上怎么办呢?那就需要我们的@Parm注解了,该注解的作用可以看成是给参数起别名:

MyBatis基本常用的注解大概就说这么多后续再补充
二、动态SQL
何为动态SQL,就是服务器根据用户请求从而选择性的发送SQL语句,最典型的就是修改了,一个表中有多个字段,如果用户只需修改其中一个即可,那我们的SQL语句就没办法确定要修改哪一个,以前的做法是再修改前先获取所有的字段信息,然后按照用户所做的修改一 一进行比对,最后统一进行修改。这样的话我们就需要再dao将所有的字段都修改一次了,这和删除以后再新增一个区别不大,而且浪费资源,所有才有了动态SQL的诞生,动态sql只能是在xml文件中进行配置
if : If标签通常用于WHERE语句中,通过判断参数值来决定是否使用某个查询条件,它也经常用于UPDATE语句中判断是否更新某一个字段,还可以在INSERT语句中用来判断是否插入某个字段的值。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.lhf.dao.UserDao">
<update id="modify">
update user set
<if test="pwd!=null">
pwd=#{pwd}
</if>
where
<if test="id>0">
id=#{id}
</if>
</update>
</mapper>
类似于java中的if判断语句,test中为判断条件。
choose:上一部分的if标签提供了基本的条件判断,但是它无法实现if....else、if....else..... 的逻辑,要想实现这样的逻辑,就需要使用到choose when otherwise标签。choose元素中包含when和otherwise两个标签,一个choose中至少包含一个when,有0个或1个otherwise。
<select id="select" resultType="User">
select * from user where 1=1
<choose>
<when test="name!=null and name!=''">
and name=#{name}
</when>
<when test="id!=-1">
and id=#{id}
</when>
<otherwise>
and name="程序员"
</otherwise>
</choose>
</select>
where:Where标签的作用:如果该标签包含的元素有返回值,就插入一个where;如果where 后面的字符串是以and和or开头,就将它剔除。
<select id="select" resultType="User">
select * from user<!--使用了where标签,无需手动编写where条件-->
<where>
<choose>
<when test="name!=null and name!=''">
and name=#{name}
</when>
<when test="id!=-1">
and id=#{id}
</when>
<otherwise>
and name="程序员"
</otherwise>
</choose>
</where>
</select>
set:Set标签的作用:如果该标签包含的元素中有返回值,就插入一个set;如果set后面的字符串是以逗号结尾的,就把这个逗号剔除
<update id="modify" parameterType="User">
<!--如果参数类型是一个对象,那么sql语句中#{对象的属性名}-->
update user
<!--使用<set>标签替代set语句-->
<set>
<if test="name!=null and name !=''">
name=#{name},
</if>
</set>
where id=#{id}
</update>
trim:Where和set标签的功能都可以使用trim标签来实现。
<trim prefix="WHERE" prefixOverrides="AND|OR"> </trim>
<trim prefix="SET" suffixOverrides=","> </trim>
trim标签有如下属性:
prefix:当trim元素中包含内容时,会给内容增加prefix指定的前缀
prefixOverrides:当trim元素中包含内容时,会把内容中匹配的前缀去掉
suffix:当trim元素中包含内容时,会给内容增加suffix指定的后缀
suffixOverrides:当trim元素中包含内容时,会把内容中匹配的后缀去掉
foreach:可以生成一系列的值,这个标签主要用于SQL的in语句后面 foreach元素的属性主要有 item,index,collection,open,separator,close。
item:示集合中每一个元素进行迭代时的别名,
index:指定一个名字,用于表示在迭代过程中,每次迭代到的位置,
open:表示该语句以什么开始,
separator:表示在每次进行迭代之间以什么符号作为分隔 符,
close:表示该语句以什么结束
(1)foreach实现in集合
使用foreach元素可以in 集合|数组
1.foreach元素in array数组
接口方法如下:
//根据插入的id数组获取用户
List<User> findUserByIds(int[] ids);
在UserMapper.xml中新增select节点
<select id="findUserByIds" resultType="User">
select * from account
<!--此处必须使用array 不能使用参数名-->
<if test="array.length>0">
where id IN
<foreach collection="array" open="(" close=")" separator="," item="item">
#{item}<!--item此时表示数组中的元素-->
</foreach>
</if>
</select>
新增测试代码
@Test
public void test04(){
//检索id为3,5的用户
List<User> userByIds = mapper.findUserByIds(new int[]{3, 5});
System.out.println(userByIds);
}
2.foreach元素in 普通list集合
//根据插入的id集合获取用户
List<User> findUserByIds(List<Integer> lists);
修改select节点如下
<select id="findUserByIds" resultType="User">
select * from account
<!--此处必须使用list 不能使用参数名-->
<if test="list.size>0">
where id IN
<foreach collection="list" open="(" close=")" separator="," item="item">
#{item}<!--item此时表示集合中的元素-->
</foreach>
</if>
</select>
测试代码如下
@Test
public void test04(){
//检索id为3,5的用户
List<Integer> lists=new ArrayList<>();
lists.add(3);
lists.add(5);
List<User> userByIds = mapper.findUserByIds(lists);
System.out.println(userByIds);
}
3.foreach元素in 自定义list集合
修改上述代码,将findUserByIds方法修改如下:
//根据插入的id集合获取用户
List<User> findUserByIds(List<User> lists);
修改select节点如下:
<select id="findUserByIds" resultType="User">
select * from account
<!--此处必须使用list 不能使用参数名-->
<if test="list.size>0">
where id IN
<foreach collection="list" open="(" close=")" separator="," item="item">
#{item.id}<!--item此时表示集合中的元素User对象-->
</foreach>
</if>
</select>
修改测试代码如下:
@Test
public void test04(){
//检索id为3,5的用户
List<User> lists=new ArrayList<>();
User user=new User();
User user1=new User();
user.setId(3);
user1.setId(5);
lists.add(user);
lists.add(user1);
List<User> userByIds = mapper.findUserByIds(lists);
System.out.println(userByIds);
}
MyBatis注解及动态Sql的更多相关文章
- MyBatis注解配置动态SQL
MySQL创建表 DROP TABLE IF EXISTS `tb_employee`; CREATE TABLE `tb_employee` ( `id` int(11) NOT NULL AUTO ...
- MyBatis 注解使用动态SQL
使用MyBatis很长时间了,一直使用的是XML配置的 SQL,刚好在上一个项目中尝试使用注解方式开发,主要是由于XML配置过于繁琐,注解可以直接写在Mapper函数上,更加的方便一些. 在注解上不能 ...
- mybatis注解开发-动态SQL
实体类以及表结构 在mybatis-config.xml中注册mapper接口 -------------------------- 动态查询@SelectProvider EmployeeMappe ...
- Mybatis之注解实现动态sql
通过注解实现动态sql一共需要三部:1.创建表,2.创建entity类,3.创建mapper类, 4.创建动态sql的Provider类.1.和2.可以参见该系列其他文章,这里主要对3和4进行演示,并 ...
- 【mybatis深度历险系列】mybatis中的动态sql
最近一直做项目,博文很长时间没有更新了,今天抽空,学习了一下mybatis,并且总结一下.在前面的博文中,小编主要简单的介绍了mybatis中的输入和输出映射,并且通过demo简单的介绍了输入映射和输 ...
- Mybatis入门之动态sql
Mybatis入门之动态sql 通过mybatis提供的各种标签方法实现动态拼接sql. 1.if.where.sql.include标签(条件.sql片段) <sql id="sel ...
- mybatis 详解------动态SQL
mybatis 详解------动态SQL 目录 1.动态SQL:if 语句 2.动态SQL:if+where 语句 3.动态SQL:if+set 语句 4.动态SQL:choose(when,o ...
- mybatis中的动态SQL
在实际开发中,数据库的查询很难一蹴而就,我们往往要根据各种不同的场景拼接出不同的SQL语句,这无疑是一项复杂的工作,我们在使用mybatis时,mybatis给我们提供了动态SQL,可以让我们根据具体 ...
- Mybatis映射文件动态SQL语句-01
因为在很多业务逻辑复杂的项目中,往往不是简单的sql语句就能查询出来自己想要的数据,所有mybatis引入了动态sql语句, UserMapper.xml <?xml version=" ...
随机推荐
- Python—程序设计:观察者模式
观察者模式 内容:定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时, 所有依赖于它的对象都得到通知并被自动更新.观察者模式又称“发布-订阅”模式. 角色: 抽象主题(Subject) 具体 ...
- JavaScript学习总结(七)
这一讲我们来学习DOM编程(十分重要),有了DOM编程,我们就可以操作任意的HTML元素了. DOM,文档对象模型 一个html页面被浏览器加载的时候,浏览器就会对整个html页面上的所有标签都会创建 ...
- vue打包空白及字体路径错误问题
vue项目打包后空白 在config/index.js文件中 assetsPublicPath: '/', 改为 assetsPublicPath: './', build: { // Templat ...
- 详解Cisco ACS AAA认证-1(转)
转自:http://www.360doc.com/content/12/0611/17/8797027_217495523.shtml作者:luobo2012 近来,有些同学会问到关于AAA认证的问题 ...
- 3)在View中添加LBUTTONDOWN(标准消息)
1)消息一共分为四类: (1)标准消息-->以WM_ 开头的都是标准消息 (2)命令消息----> 菜单 工具条 快捷键(两个按键的组合是快捷键,一个按键是 WM_KEYDOWN( ...
- JDK8新特性之stream
stream中有很多方法,讲一些常用的. 1.forEach(),遍历方法,很简单,对于一般的遍历可以替代for循环 List<String> strings = Arrays.asLis ...
- python3拆包详解
对于可迭代对象,如元组.列表.字符串.集合.字典这些可迭代对象都可以被拆包,拆包是指将一个结构中的数据拆分为多个单独变量中.拆包的方式大致有两种,一种是以变量的方式来接收,另一种是用'*'号.下面先讲 ...
- 2.windows-oracle实战第二课 -用户管理
创建用户:在oracle中创建一个用户有create user语句,一般是具有dba(数据库管理员)的权限才能使用.用户创建在所在的实例数据库中. 给用户修改密码:passw 给别人修改密码需要dba ...
- linux(centos 7)安装及使用yum
yum介绍: Yum(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及CentOS中的Shell前端软件包管理器.基于RPM包管理,能够从指定的 ...
- [原]win10拖拽贴靠功能注册表项调查记录
win10的拖拽贴靠功能被禁用了,偶然的机会,在设置中看到了相关的设置项,如下图 直觉告诉我一定是设置注册表中的某一项,于是决定调查下具体的注册表位置.请出procmon.exe,然后关闭贴靠功能,停 ...