• Mybatis中的模糊查询和sql中字符串拼接


    Mybatis中的模糊查询和sql中字符串拼接

    Mybatis中的模糊查询

    今天下午做的一个功能,要用到模糊查询,字段是description,刚开始我的写法用的是sql中的模糊查询语句,

    但是这个有问题,只有将字段的全部值传入其中,才能查询,所以不是迷糊查询。

    后来经过搜索,发现要加上一个concat字段,要先将字符串拼接后,才能实现模糊查询。

    改成这个样子后,模糊查询功能实现。

    在我搜索到的博客中海油别的几种写法,但是试验了两个,有一个成功,另外一个没能实现模糊查询,但是目前还不知道错误在哪里。如果有人知道,请赐教。

    他的博客地址是:https://blog.csdn.net/luqin1988/article/details/7865643

    第一种方法:

    1. sql中字符串拼接

    SELECT * FROM tableName WHERE name LIKE CONCAT(CONCAT('%', #{text}), '%');

    我就是按照此方法实现了功能。

    其实还有种方法:像这样写也行:

    第二种方法:

    2. 使用 ${...} 代替 #{...}

    SELECT * FROM tableName WHERE name LIKE '%${text}%';

    这个我试过之后,发现并没有实现模糊查询的功能,而且目前也不知道哪里出错了,如果有人知道请指教。

    第三种方法:

    3. 程序中拼接

    Java
    
    // String searchText = "%" + text + "%";
    
    String searchText = new StringBuilder("%").append(text).append("%").toString();
    
    parameterMap.put("text", searchText);
    
    SqlMap.xml
    
    SELECT * FROM tableName WHERE name LIKE #{text};

    这个方法我没有试过,但是还是记录下来,以后试试

    还有第四种方法

    4. 大小写匹配查询

    SELECT *  FROM TABLENAME  WHERE UPPER(SUBSYSTEM) LIKE '%' || UPPER('jz') || '%'
    
    或者 
    
    SELECT *   FROM TABLENAME  WHERE LOWER(SUBSYSTEM) LIKE '%' || LOWER('jz') || '%'
    
    正确。
  • 相关阅读:
    下拉菜单年月日
    把某些字符替换成**;
    单击向下滚动,单击停止滚动,下拉显示top,点击top返回顶部
    去除网页中的选中和右键菜单
    表单验证必须为6-12位英文字母去除首尾空格
    免费的海量编程中文书籍索引-都是干货【强烈建议收藏】
    图标搜索网站
    表单验证
    HDU 6319 Problem A. Ascending Rating(单调队列)
    Palindrome Function HDU
  • 原文地址:https://www.cnblogs.com/haolb123/p/16553103.html
Copyright © 2020-2023  润新知