色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

mybatis的動(dòng)態(tài)SQL和模糊查詢(xún)實(shí)例詳解

瀏覽:99日期:2023-10-19 16:04:13

現(xiàn)在以一個(gè)例子來(lái)介紹mybatis的動(dòng)態(tài)SQL和模糊查詢(xún):通過(guò)多條件查詢(xún)用戶(hù)記錄,條件為姓名模糊匹配,并且年齡在某兩個(gè)值之間。

新建表d_user:

create table d_user( id int primary key auto_increment, name varchar(10), age int(3)); insert into d_user(name,age) values(’Tom’,12); insert into d_user(name,age) values(’Bob’,13); insert into d_user(name,age) values(’Jack’,18);

建表成功:

mybatis的動(dòng)態(tài)SQL和模糊查詢(xún)實(shí)例詳解

新建實(shí)體類(lèi)User:

public class User { private Integer id; private String name; private Integer age;//getters and setters @Override public String toString() { return 'User [id=' + id + ', name=' + name + ', age=' + age + ']'; } public User(Integer id, String name, Integer age) { super(); this.id = id; this.name = name; this.age = age; } public User() { super(); }}

創(chuàng)建查詢(xún)條件實(shí)體類(lèi)ConditionUser:

public class ConditionUser { private String name; private int minAge; private int maxAge;//getters and setters public ConditionUser(String name, int minAge, int maxAge) { super(); this.name = name; this.minAge = minAge; this.maxAge = maxAge; } public ConditionUser() { super(); }}

新建映射文件userMapper.xml:

<?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.mybatis.test7.userMapper'> <select parameterType='ConditionUser' resultType='User'> SELECT * FROM d_user WHERE age &gt;= #{minAge} AND age &lt;= #{maxAge} <if test='name!=null'> AND name LIKE CONCAT(CONCAT(’%’,#{name}),’%’)</if> </select></mapper>

編寫(xiě)測(cè)試類(lèi):

public class Test { private SqlSessionFactory sessionFactory; private SqlSession session; @Before public void init(){ //讀取配置文件 String resource = 'conf.xml'; InputStream is = this.getClass().getClassLoader().getResourceAsStream(resource); //創(chuàng)建SqlSessionFactory和SqlSession sessionFactory = new SqlSessionFactoryBuilder().build(is); session = sessionFactory.openSession(); } @After public void free(){ session.commit(); session.close(); } @org.junit.Test public void getUser() { String statement = 'com.mybatis.test7.userMapper'+'.getUser'; ConditionUser conditionUser = new ConditionUser('o', 13, 18); List<User> list = session.selectList(statement, conditionUser); System.out.println(list); }}

運(yùn)行結(jié)果:

mybatis的動(dòng)態(tài)SQL和模糊查詢(xún)實(shí)例詳解

注意:

1. 在配置文件中編寫(xiě)sql語(yǔ)句時(shí),為防止大于號(hào)和小于號(hào)在表示大小關(guān)系和表示標(biāo)簽符號(hào)之間產(chǎn)生混淆,所以通常用&gt;和&lt;來(lái)代替sql語(yǔ)句中大于號(hào)和小于號(hào)。

2. 在SQL語(yǔ)句中添加動(dòng)態(tài)SQL標(biāo)簽if的原因是,當(dāng)在后臺(tái)獲取的name屬性值為null時(shí),防止生成where name like %null%的條件判斷語(yǔ)句,正確的邏輯應(yīng)該是,當(dāng)傳來(lái)的name屬性值為null時(shí),取消此篩選條件,即不使用where name like ?的判斷條件。在mybatis中,可用的動(dòng)態(tài)SQL標(biāo)簽有:if,choose(when,otherwise),trim(where,set),foreach。

3. 在使用模糊查詢(xún)時(shí),拼接%+#{name}+%的方法有如下幾種:

(1).像上述例子中一樣,在SQL語(yǔ)句中使用CONCAT關(guān)鍵字。

(2).使用${}代替#{}:

<?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.mybatis.test7.userMapper'> <select parameterType='ConditionUser' resultType='User'> SELECT * FROM d_user WHERE age &gt;= #{minAge} AND age &lt;= #{maxAge} <if test='name!=null'> AND name LIKE ’%${name}%’</if> </select></mapper>

注意,默認(rèn)情況下,使用#{}語(yǔ)法,MyBatis會(huì)產(chǎn)生PreparedStatement語(yǔ)句,并且安全地設(shè)置PreparedStatement參數(shù),這個(gè)過(guò)程中MyBatis會(huì)進(jìn)行必要的安全檢查和轉(zhuǎn)義。例如:

執(zhí)行SQL:select * from emp where name = #{employeeName}

參數(shù):employeeName=>Smith

解析后執(zhí)行的SQL:select * from emp where name = ?

執(zhí)行SQL:Select * from emp where name = ${employeeName}

參數(shù):employeeName傳入值為:Smith

解析后執(zhí)行的SQL:Select * from emp where name =Smith

綜上所述,${}方式可能會(huì)引發(fā)SQL注入的問(wèn)題,同時(shí)也會(huì)影響SQL語(yǔ)句的預(yù)編譯,所以從安全性和性能的角度出發(fā),應(yīng)盡量使用#{}。當(dāng)需要直接插入一個(gè)不做任何修改的字符串到SQL語(yǔ)句中,例如在ORDER BY后接一個(gè)不添加引號(hào)的值作為列名,這時(shí)候就需要使用${}。

(3).在程序中拼接。

總結(jié)

到此這篇關(guān)于mybatis的動(dòng)態(tài)SQL和模糊查詢(xún)的文章就介紹到這了,更多相關(guān)mybatis動(dòng)態(tài)SQL模糊查詢(xún)內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

相關(guān)文章:
主站蜘蛛池模板: 美女扒开腿让男人桶个爽 | 久久99视频 | 一级成人毛片 | 国产成人精品免费视频大全可播放的 | 国产成人久久精品二区三区 | 国产精品久久国产三级国电话系列 | 精品久久一区二区 | 亚洲综合网在线观看 | 亚洲欧美国产高清va在线播放 | 亚洲欧美精品一区天堂久久 | 久久99精品综合国产首页 | 国产毛片一级国语版 | 欧美一级片播放 | 国产午夜不卡在线观看视频666 | 亚洲精品一区二区久久这里 | 香港三澳门三日本三级 | 精品厕拍 | 草草在线免费视频 | 全部免费毛片免费播放 | 免费国产成人手机在线观看 | 女初高中福利视频在线观看 | 精品欧美高清不卡在线 | 久久加勒比 | 亚洲三级毛片 | 亚洲欧美综合国产不卡 | 在线观看va | 日韩18在线观看地址 | 欧美激情国内自拍偷 | 日本a级片免费看 | 免费高清不卡毛片在线看 | 91成人午夜在线精品 | 欧美一区二区三区gg高清影视 | 国产精品久久久久久久专区 | 亚洲欧美网址 | 亚洲国产品综合人成综合网站 | 另类专区欧美 | 国产精品美乳免费看 | 亚洲欧美国产日韩天堂在线视 | 亚洲免费小视频 | 成人亚洲欧美日韩中文字幕 | 亚洲国产91 |