zoukankan      html  css  js  c++  java
  • 动态SQL之模糊查询

    模糊查询学习了三种:

    DAO层

    // 可以使用
    List<User> wherelike01(String user_name);
    
    // 忘记
    List<User> wherelike02(Map<String, Object> map);
    
    // 推荐使用
    List<User> wherelike03(String user_name)

    测试类

    @Test
        public void where语句测试01() {
            SqlSession sqlSession = null;
            try {
                sqlSession = MyBatisUtils.getSqlSession();
                sqlSession.getMapper(UserDao.class).wherelike01("宋%");
            } catch (Exception e) {
                logger.debug(e.getMessage());
                throw new RuntimeException(e.getMessage());
            } finally {
                MyBatisUtils.closeSqlSession(sqlSession);
            }
        }
    @Test
        public void where语句测试02$() {
            SqlSession sqlSession = null;
            try {
                Map<String, Object> map = new HashMap<String, Object>();
                map.put("account", "宋");
                sqlSession = MyBatisUtils.getSqlSession();
                sqlSession.getMapper(UserDao.class).wherelike02(map);
            } catch (Exception e) {
                logger.debug(e.getMessage());
                throw new RuntimeException(e.getMessage());
            } finally {
                MyBatisUtils.closeSqlSession(sqlSession);
            }
        }
    @Test
    public void where语句测试03推荐() {
      SqlSession sqlSession = null;
      try {
        sqlSession = MyBatisUtils.getSqlSession();
        sqlSession.getMapper(UserDao.class).wherelike03("宋");
        } catch (Exception e) {
          logger.debug(e.getMessage());
          throw new RuntimeException(e.getMessage());
        } finally {
          MyBatisUtils.closeSqlSession(sqlSession);
        }
    }

    Mapper中 

    <mapper namespace="com.shxt.dao.UserDao">
           <select id="wherelike01" parameterType="string" resultType="com.shxt.model.User">
             SELECT
                *
            FROM
                USER
            WHERE
                user_name LIKE #{user_name}
           </select>
            <select id="wherelike02" parameterType="map" resultType="com.shxt.model.User">
               SELECT
                    *
                FROM
                    USER
                WHERE
                    user_name LIKE '${user_name}%'
           </select>
             <select id="wherelike03" parameterType="string" resultType="com.shxt.model.User">
               SELECT
                    *
                FROM
                    USER
                WHERE
                    user_name LIKE CONCAT(#{user_name}, '%')
           </select>
    </mapper>

      

  • 相关阅读:
    [VBA]根据身份证号码计算年龄的Excel函数
    [VBA]发布一个计算桩号之差的Excel自定义函数(VBA)
    [VBA]用一个简单例子说明如何在Excel中自定义函数
    元素定位工具:Chrome浏览器ChroPath插件
    68 个 Python 内置函数
    Python错误重试
    jenkins 中展示漂亮的 HTML 测试报告
    python解决接口数据使用了RSA加密和签名
    Python装饰器用法
    Pycharm中文版教程
  • 原文地址:https://www.cnblogs.com/blogofcookie/p/5573560.html
Copyright © 2011-2022 走看看