Mybatis动态SQL之if、choose、where、set、trim、foreach标记实例详解

网友投稿 206 2023-07-07


Mybatis动态SQL之if、choose、where、set、trim、foreach标记实例详解

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

if标记

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

数据库中的数据为:

MyBatisConfig.xml

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

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

JiKeUser.xml

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";

RUrpEvLudeader 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标记实例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,会及时回复大家的。在此也非常感谢大家对我们网站的支持!

JiKeUser.xml

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";

RUrpEvLudeader 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}

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

#{item}

测试:

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


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java NIO原理图文分析及代码实现
下一篇:JQ选择器_选择同类元素的第N个子元素的实现方法
相关文章

 发表评论

暂时没有评论,来抢沙发吧~