MyBatis多條件查詢看這一篇就夠了

一:使用動(dòng)態(tài)SQL完成多條件查詢

a:使用if+where實(shí)現(xiàn)多條件查詢

首先場(chǎng)景需求躲查,有 個(gè)年級(jí)和班級(jí)表术吝,第一個(gè)要求是根據(jù)模糊查詢姓名转捕,和年齡大小進(jìn)行條件查詢园细,接口層方法

public  List<student>  getStudentByIf(student stu);

其次是映射文件的配置

<select id="getStudentByIf" parameterType="stu" resultType="stu">
        select * from student
       <where>
           <if test="stuAge!=0">
           and stuAge>#{stuAge}
       </if>
             <if test="stuName!=null">
                 and stuName LIKE '%' #{stuName} '%'
             </if>

       </where>

    </select>

測(cè)試

studentDao dao = MyBatis.getSessionTwo().getMapper(studentDao.class);
        student stu = new student();
        stu.setStuName("z");
       // stu.setStuAge(19);
        List<student> list=  dao.getStudentByIf(stu);
       
        for (student item:list) {
            System.out.println("----------"+item.getStuName());
        }  打印效果
----------zhangyu----------zy----------zy----------zhang

b:choose when 分類

這種方式和java中choose循環(huán)結(jié)構(gòu)原理是一樣的,判斷多種情況昔馋,只要修改一下映射文件即可

接口 類

public List<student> getAllStudentByLike(Map<String, Object> userMap);  //使用map作為參數(shù)

映射文件

<select id="getAllStudentByLike" parameterType="Map" resultType="stu">
        select * from student
        <where>
        <choose>
            <when test="stuName!=null">
                 stuName like CONCAT('%',#{stuName},'%')
            </when>
            <when test="stuAge!=0">
                 stuAge> #{stuAge}
            </when>
<otherwise>    1=1</otherwise>

        </choose>
        </where>
    </select>

結(jié)果

zhangyu
zy
zy
zhang

c:使用foreach完成復(fù)雜 查詢筹吐,有三種方式,

第一種:傳入的參數(shù)為數(shù)組類型

//傳一組 xueshengID 
public List<student> getStudentBystuId_foreach_array(Integer[] ints);




映射文件配置
 <!--跟據(jù)學(xué)生id查詢學(xué)生Interger-->
    <select id="getStudentBystuId_foreach_array" resultMap="studentList">
        select * from student
        <if test="array.length>0">
        where stuId IN
        /*數(shù)組形式傳入學(xué)生Id*/
        <foreach collection="array" item="stu" open="(" separator="," close=")">
              #{stu}
        </foreach>
        </if>
    </select>

測(cè)試類

Integer[] ints = {2,3,4};
        List<student> list = dao.getStudentBystuId_foreach_array(ints);
        for (student item:list) {
            System.out.println(item.getStuName());
        }

第二種:傳入list集合

public List<student> getStudentBystuId_foreach_list(List<Integer> list);
<!--跟據(jù)學(xué)生id查詢學(xué)生list方式-->
    <select id="getStudentBystuId_foreach_list" resultMap="studentList">
        select * from student
        <if test="list.size>0">
            where stuId IN
        /*集合形式傳入學(xué)生Id*/
        <foreach collection="list" item="stu" open="(" separator="," close=")">
            #{stu}
        </foreach>
        </if>
    </select>

測(cè)試:

studentDao dao = MyBatis.getSessionTwo().getMapper(studentDao.class);
        Integer ints = 2;
        List<Integer> list = new ArrayList<Integer>();
        list.add(ints);
        List<student> stulist = dao.getStudentBystuId_foreach_list(list);
        for (student item:stulist) {
            System.out.println(item.getStuName());
        }

第三種:根據(jù)Map集合

public List<student> getStudentBystuId_foreach_map(Map<String, Object> stuMap);
<!--跟據(jù)學(xué)生id查詢學(xué)生map方式-->
    <select id="getStudentBystuId_foreach_map" resultMap="studentList">
        select * from student where stuId IN
        /*集合形式傳入學(xué)生Id*/
        <foreach collection="stuId" item="stu" open="(" separator="," close=")">    <!--collection是自己定義的秘遏,就是map的key值-->
            #{stu}
        </foreach>
    </select>
Map<String ,Object> stumap = new HashMap<String, Object>();
        List<Integer> listStuId = new ArrayList<Integer>();
        listStuId.add(2);
        listStuId.add(3);
        listStuId.add(4);
        stumap.put("stuId",listStuId);
         List<student> list = dao.getStudentBystuId_foreach_map(stumap);
        for (student item:list
             ) {
            System.out.println(item.getStuName());
        }

打印結(jié)果可以執(zhí)行以下丘薛。

d;一對(duì)多的兩種實(shí)現(xiàn)方式

主要是resultMapper里的配置不同

接口方法

public grade getGradeById(int gradeId);

映射文件配置

<!--實(shí)現(xiàn)一 對(duì)多的第一中實(shí)現(xiàn)-->
    <resultMap id="gradeMapOne" type="grade">
        <id column="gradeId" property="gradeId"></id>
        <result column="gradeName" property="gradeName"></result>
        <collection property="gatStudent" ofType="stu">
            <id column="stuUd" property="stuId"></id>
            <result column="stuName" property="stuName"></result>
            <result column="stuAge" property="stuAge"></result>
        </collection>
    </resultMap>
    <!--實(shí)現(xiàn)一 對(duì)多的第二中實(shí)現(xiàn)-->
    <resultMap id="gradeMap" type="entity.grade">
        <id column="gradeId" property="gradeId"></id>
        <result column="gradeName" property="gradeName"></result>
        <collection property="gatStudent" ofType="student" select="getStudentById" column="gradeId"></collection>    <!--column的值主要作為下次查詢的條件,既查詢學(xué)生的條件-->
    </resultMap>

    <select id="getGradeById" resultMap="gradeMapOne">
        select * from grade,student where grade.gradeId = student.stuGrade and gradeId = #{gradeId}
    </select>
    <!--ddddddddddddddddddd-->
    <select id="getGradeById" resultMap="gradeMap">
        select * from grade where gradeId=#{gradeId}
    </select>

    <select id="getStudentById" resultType="entity.student">
        select * from student where stuGrade = #{stuGrade}
    </select>
<select id="getGradeById" resultMap="gradeMapOne">
        select * from grade,student where grade.gradeId = student.stuGrade and gradeId = #{gradeId}
    </select>
    <!--ddddddddddddddddddd-->
    <select id="getGradeById" resultMap="gradeMap">
        select * from grade where gradeId=#{gradeId}
    </select>

    <select id="getStudentById" resultType="entity.student">
        select * from student where stuGrade = #{stuGrade}
    </select>
@Test
    public void  TestConn(){
       gradeDao dao = MyBatis.getSessionTwo().getMapper(gradeDao.class);

       grade grade = dao.getGradeById(1);
       for (student item:grade.getGatStudent()            ) {
           System.out.println(item.getStuName());
       }

    }

兩種方式都能實(shí)現(xiàn)邦危,打印效果

方案一打印效果

==> Preparing: select * from grade,student where grade.gradeId = student.stuGrade and gradeId = ? ============一條sql
==> Parameters: 1(Integer)
<== Columns: gradeId, gradeName, stuId, stuName, stuAge, stuGrade
<== Row: 1, S1297, 2, zhangyu, 19, 1
<== Row: 1, S1297, 3, zy, 20, 1
<== Row: 1, S1297, 4, zy, 21, 1
<== Total: 3
zhangyu
zy
zy

Process finished with exit code 0

方案二打印效果

==> Preparing: select * from grade where gradeId=? ==========第一條sql
==> Parameters: 1(Integer)
<== Columns: gradeId, gradeName
<== Row: 1, S1297
====> Preparing: select * from student where stuGrade = ? ==========第二條sql
====> Parameters: 1(Long)
<==== Columns: stuId, stuName, stuAge, stuGrade
<==== Row: 2, zhangyu, 19, 1
<==== Row: 3, zy, 20, 1
<==== Row: 4, zy, 21, 1
<==== Total: 3
<== Total: 1
zhangyu
zy
zy

Process finished with exit code 0

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末洋侨,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子倦蚪,更是在濱河造成了極大的恐慌希坚,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,820評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件陵且,死亡現(xiàn)場(chǎng)離奇詭異裁僧,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)滩报,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,648評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來播急,“玉大人脓钾,你說我怎么就攤上這事∽” “怎么了可训?”我有些...
    開封第一講書人閱讀 168,324評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我握截,道長(zhǎng)飞崖,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,714評(píng)論 1 297
  • 正文 為了忘掉前任谨胞,我火速辦了婚禮固歪,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘胯努。我一直安慰自己牢裳,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,724評(píng)論 6 397
  • 文/花漫 我一把揭開白布叶沛。 她就那樣靜靜地躺著蒲讯,像睡著了一般。 火紅的嫁衣襯著肌膚如雪灰署。 梳的紋絲不亂的頭發(fā)上判帮,一...
    開封第一講書人閱讀 52,328評(píng)論 1 310
  • 那天,我揣著相機(jī)與錄音溉箕,去河邊找鬼晦墙。 笑死,一個(gè)胖子當(dāng)著我的面吹牛约巷,可吹牛的內(nèi)容都是我干的偎痛。 我是一名探鬼主播,決...
    沈念sama閱讀 40,897評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼独郎,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼踩麦!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起氓癌,我...
    開封第一講書人閱讀 39,804評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤谓谦,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后贪婉,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體反粥,經(jīng)...
    沈念sama閱讀 46,345評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,431評(píng)論 3 340
  • 正文 我和宋清朗相戀三年疲迂,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了才顿。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,561評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡尤蒿,死狀恐怖郑气,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情腰池,我是刑警寧澤尾组,帶...
    沈念sama閱讀 36,238評(píng)論 5 350
  • 正文 年R本政府宣布忙芒,位于F島的核電站,受9級(jí)特大地震影響讳侨,放射性物質(zhì)發(fā)生泄漏呵萨。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,928評(píng)論 3 334
  • 文/蒙蒙 一跨跨、第九天 我趴在偏房一處隱蔽的房頂上張望潮峦。 院中可真熱鬧,春花似錦歹叮、人聲如沸跑杭。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,417評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽德谅。三九已至,卻和暖如春萨螺,著一層夾襖步出監(jiān)牢的瞬間窄做,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,528評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工慰技, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留椭盏,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,983評(píng)論 3 376
  • 正文 我出身青樓吻商,卻偏偏與公主長(zhǎng)得像掏颊,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子艾帐,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,573評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容