mybatis更新数据 set加if_Mybatis动态SQL之if、choose、where、set、trim、foreach标记实例详解...

动态SQL就是动态的生成SQL。

if标记

假设有这样一种需求:查询用户,当用户名不等于“admin”的时候,我们还需要密码为123456。

数据库中的数据为:

MyBatisConfig.xml

/p>

PUBLIC "-//mybatis.org//DTD Config 3.0//EN"

"http://mybatis.org/dtd/mybatis-3-config.dtd">

JiKeUser.xml

/p>

PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"

"http://mybatis.org/dtd/mybatis-3-mapper.dtd">

SELECT * FROM jikebook.jikeuser

WHERE 1=1

AND password=#{password}

测试类:

package jike.book.test;

import jike.book.pojo.JiKeUser;

import org.apache.ibatis.io.Resources;

import org.apache.ibatis.session.SqlSession;

import org.apache.ibatis.session.SqlSessionFactory;

import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import java.io.IOException;

import java.io.Reader;

import java.util.List;

/**

* DateTime: 2016/9/6 13:36

* 功能:

* 思路:

*/

public class TestSQL {

public static void main(String[] args) {

// 资源路径

String resource="jike/book/map/MyBatisConfig.xml";

Reader reader=null;

SqlSession session;

try {

reader= Resources.getResourceAsReader(resource);

} catch ( IOException e ) {

e.printStackTrace();

}

SqlSessionFactory sqlMapper=new SqlSessionFactoryBuilder().build(reader);

session=sqlMapper.openSession();

JiKeUser jiKeUser=new JiKeUser();

jiKeUser.setPassword("123456");

List userList=session.selectList("selectSQL",jiKeUser);

for ( JiKeUser user:userList ) {

System.out.println("userName:"+user.getUserName());

}

session.close();

}

}

运行结果为:

choose标记

假设我们当前有这么一个需求:查询用户,如果用户名不为空就加上用户名这个条件,如果id不为空也加上id这个条件,否则的话就是设置密码不为空,这就是一个多路选择。

MyBatisConfig.xml不改变,在JikeUser.xml中加上:

select * from jikeuser where 1=1

and userName like #{userName}

and id =#{id}

and password is not null

测试类:假设用户名不为空:

package jike.book.test;

import jike.book.pojo.JiKeUser;

import org.apache.ibatis.io.Resources;

import org.apache.ibatis.session.SqlSession;

import org.apache.ibatis.session.SqlSessionFactory;

import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import java.io.IOException;

import java.io.Reader;

import java.util.List;

/**

* DateTime: 2016/9/6 13:36

* 功能:

* 思路:

*/

public class TestSQL {

public static void main(String[] args) {

// 资源路径

String resource="jike/book/map/MyBatisConfig.xml";

Reader reader=null;

SqlSession session;

try {

reader= Resources.getResourceAsReader(resource);

} catch ( IOException e ) {

e.printStackTrace();

}

SqlSessionFactory sqlMapper=new SqlSessionFactoryBuilder().build(reader);

session=sqlMapper.openSession();

JiKeUser jiKeUser=new JiKeUser();

jiKeUser.setUserName("YEN");

List userList=session.selectList("selectJiKeUserChoose",jiKeUser);

for ( JiKeUser user:userList ) {

System.out.println("userName:"+user.getUserName());

}

session.close();

}

}

结果为:

假设不设置用户名这个条件,即注释掉jiKeUser.setUserName("YEN");:

where标记、set标记

上面我们在choose中查询是不能确定子连接条件中的and是写还是不写,因此加了一个1=1.而where会只能的去判断该不该加。

select * from jikeuser

and userName like #{userName}

and id =#{id}

set标记智能赋值,会自动去掉多余的”,”。

update JiKeUser

userName=#{userName},

password=#{password},

where id=#{id}

操作之前的数据:

操作:

操作结果:

UPDATE JiKeUser

userName = #{userName},

password=#{password},

foreach标记

通常用于循环查询或循环赋值

select * from jikeuser

id in

open="(" separator="," close=")">

#{item}

测试:

以上所述是小编给大家介绍的Mybatis动态SQL之if、choose、where、set、trim、foreach标记实例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值