亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Mybatis中怎么使用in()查詢

發布時間:2022-08-27 09:21:36 來源:億速云 閱讀:329 作者:iii 欄目:開發技術

本篇內容主要講解“Mybatis中怎么使用in()查詢”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Mybatis中怎么使用in()查詢”吧!

我們在mysql中使用in查詢的方式是這樣的

Mybatis中怎么使用in()查詢

那在mybatis中我們使用<foreach>標簽來實現包含查詢

1 使用數組方式

Mapper:

Mybatis中怎么使用in()查詢

 Mapper.xml:

<select id="studentList" resultType="com.ywt.springboot.model.Student">
        select *
        from student
        where id in
        <foreach collection="array" index="index" item="item" open="(" separator="," close=")">
            #{item}
        </foreach>
    </select>

 :foreach中的 collection標簽中為array,item是遍歷ids中的每個元素,默認為item可以自定義。

測試類:

Mybatis中怎么使用in()查詢

我們可以使用字符串來接收參數,使用逗號分隔每個參數,然后把分隔后的參數放到集合中。

Mybatis中怎么使用in()查詢

2 使用List集合的方式

Mapper:

Mybatis中怎么使用in()查詢

 Mapper.xml

<select id="studentList" resultType="com.ywt.springboot.model.Student">
        select *
        from student
        where id in
        <foreach collection="list" index="index" item="item" open="(" separator="," close=")">
            #{item}
        </foreach>
    </select>

 使用list方式collection的value必須為list

 測試:

Mybatis中怎么使用in()查詢

3 第三種我們使用Mybatis-plus框架的條件構造器來進行查詢

@Test
    void Test(){
        QueryWrapper<Student> qw = new QueryWrapper<>();
        qw.in("id",7,9);
        List<Student> students = studentMapper.selectList(qw);
        System.out.println(students.toString());
    }

 測試結果:

[Student(id=7, name=蔡徐坤, age=18), Student(id=9, name=金科徐, age=18)]

附:Mybatis-plus的條件構造器詳細使用教程

常用函數:

函數說明

例子(以下為where后的條件,select * from user where ?)

eq等于=eq("name","張三") --> name = '張三'
ne不等于 !=ne("name","李四") --> name != '李四'
gt大于 >gt(age,18) --> age > 18 //年齡大于18歲
ge大于等于 >=ge(age,18) --> age >=18
lt小于 <lt(age,20) --> age < 20 //年齡小于20歲
le小于等于 <=le(age,20) ---> age <= 20
betweenbetween 值1 and 值2between(age,15,25) ---> 匹配15歲到25歲之間(包含15和25)
nobetweennot between 值1 and 值2notBetween(age,35,45)-->匹配不包含35-45之間的(包含35和45)
likelike '%值%'

like("name","張") --> like '%張%'

notlikenot like '%值%'notLike("name”,"張") --> not like '%張%'
likeLeftlike '%值'likeLeft("name","王") ---> like "%王"
likeRightlike '值%'likeRight("name","王") ---> like "王%"
isNull表字段 is NULLisNull("name") ---> name is null
notNull表字段 is not NULLisNull("name") ---> name is not null
in表字段in(v1,v2,v3...)in("num",{1,2,3}) ---> num in (1,2,3)
notIn表字段 not in(v1.v2,v3)notIn("num",{2,3,4}) ---> num not in (2,3,4)

使用構造器完成一個簡單的查詢

// SQL語句:select * from user where id = ?
// 使用條件構造器QueryWrapper
    @Test
    void queryWrapper(){
        QueryWrapper<User> qw = new QueryWrapper<>();
        qw.eq("id",1);
        List<User> users = userMapper.selectList(qw);
        users.forEach(System.out::print);
    }

那么再來一點更多條件的 

// 我們要查詢name里姓氏包含 ‘張',并且年齡小于30歲的
// SQL語句:select * from user where name like '張%' and age < 30
 
// 條件構造器:
    @Test
    void queryWrapper(){
        QueryWrapper<User> qw = new QueryWrapper<>();
        qw.likeRight("name","張").lt("age","30");
        List<User> users = userMapper.selectList(qw);
        users.forEach(System.out::println);
    }
// 查詢出年齡在15-25之間,并且他的名字不為空
// SQL語句:select * from user where name is not null and age between(15,25)
 
//條件構造器
    @Test
    void queryWrapper(){
        QueryWrapper<User> qw = new QueryWrapper<>();
        qw.isNotNull("name").between("age",18,25);
        List<User> users = userMapper.selectList(qw);
        users.forEach(System.out::println);
    }
// 查詢名字中帶有王的,并且年齡不小于30,郵箱為空的
// SQL語句:select * from user where name like '%王%' and age >= 30 and email is null
 
// 條件構造器:
    @Test
    void queryWrapper(){
        QueryWrapper<User> qw = new QueryWrapper<>();
        qw.like("name","王").ge("age",30).isNull("email");
        List<User> users = userMapper.selectList(qw);
        users.forEach(System.out::println);
    }

到此,相信大家對“Mybatis中怎么使用in()查詢”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

山西省| 万荣县| 永修县| 自治县| 邳州市| 应用必备| 陈巴尔虎旗| 太白县| 信宜市| 星子县| 尚志市| 宽城| 安义县| 苗栗县| 修水县| 城固县| 晋城| 铜山县| 普陀区| 聊城市| 永顺县| 察隅县| 盐源县| 楚雄市| 天门市| 仪征市| 天气| 康马县| 新化县| 金湖县| 江川县| 滨州市| 石柱| 蓬溪县| 右玉县| 达州市| 西城区| 肥西县| 广东省| 疏勒县| 伊春市|