说明:以下写法可以同时支持XML和注解的形式。

1、SQL中字符串拼接



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


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



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


3、程序中拼接

Java



// or 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') || '%'