zoukankan      html  css  js  c++  java
  • MyBatis多条件查询

    一:使用动态SQL完成多条件查询

         a:使用if+where实现多条件查询

           首先场景需求,有 个年级和班级表,第一个要求是根据模糊查询姓名,和年龄大小进行条件查询,接口层方法

           

     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>

            测试

       

     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循环结构原理是一样的,判断多种情况,只要修改一下映射文件即可

         接口 类

        

      public List<student> getAllStudentByLike(Map<String, Object> userMap);  //使用map作为参数

         映射文件

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

        结果

    zhangyu
    zy
    zy
    zhang

      c:使用foreach完成复杂 查询,有三种方式,

         第一种:传入的参数为数组类型

            

    //传一组 xueshengID 
    public List<student> getStudentBystuId_foreach_array(Integer[] ints);
    
    
    
    
    映射文件配置
     <!--跟据学生id查询学生Interger-->
        <select id="getStudentBystuId_foreach_array" resultMap="studentList">
            select * from student
            <if test="array.length>0">
            where stuId IN
            /*数组形式传入学生Id*/
            <foreach collection="array" item="stu" open="(" separator="," close=")">
                  #{stu}
            </foreach>
            </if>
        </select>

    测试类

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

      

      <!--跟据学生id查询学生list方式-->
        <select id="getStudentBystuId_foreach_list" resultMap="studentList">
            select * from student
            <if test="list.size>0">
                where stuId IN
            /*集合形式传入学生Id*/
            <foreach collection="list" item="stu" open="(" separator="," close=")">
                #{stu}
            </foreach>
            </if>
        </select>

         测试:

       

     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());
            }

        第三种:根据Map集合

         

     public List<student> getStudentBystuId_foreach_map(Map<String, Object> stuMap);

      

     <!--跟据学生id查询学生map方式-->
        <select id="getStudentBystuId_foreach_map" resultMap="studentList">
            select * from student where stuId IN
            /*集合形式传入学生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());
            }

     打印结果可以执行以下。

      d;一对多的两种实现方式

        主要是resultMapper里的配置不同

       接口方法 

       

     public grade getGradeById(int gradeId);

       映射文件配置

       

     <!--实现一 对多的第一中实现-->
        <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>
        <!--实现一 对多的第二中实现-->
        <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的值主要作为下次查询的条件,既查询学生的条件-->
        </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>
    
    
    
     

           

      @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());
           }
    
        }

    两种方式都能实现,打印效果

    方案一打印效果

    ==> 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

  • 相关阅读:
    Matlab实现图像切割
    Android --------------------ActionBar 与 ViewPager 和 ActionTab 切换 的源代码实现
    算法导论--装备线调度(升序&amp;&amp;降序输出)
    《打造七星级团队》观后感
    系统架构师秘籍(一)软件架构
    jQuery $.extend()使用方法
    Hadoop自学笔记(五)配置分布式Hadoop环境
    delete与delete [] 真正差别
    LINK : fatal error LNK1123: failure during conversion to COFF: file invalid or corrupt
    weblogic stuck实验2014-11-14
  • 原文地址:https://www.cnblogs.com/zhangyu0217----/p/7145704.html
Copyright © 2011-2022 走看看