当我们需要开发一个方法用来查询数据库的时候,往往会遇到这样一个问题:就是不知道用户到底会输入什么条件,那么怎么样处理sql语句才能让我们开发的方法不管接受到什么样的条件都可以正常工作呢?这时where '1'='1'加上list就可以完美解决这个问题了,废话少说,上代码: // 模糊查询方法 public List<person> query() { List<person> list = new ArrayList<>(); Connection con = null…
我们在做多个字段模糊查询时,是不是觉得非常麻烦?比如我要模糊查询某表多个字段存在某数据时,如下 select * from table where a like '%key%' or b like '%key%' or c like '%key%'.......... 上面的语句不但长,而且写起来好麻烦.我们是不是有更好的办法呢? 答案是肯定的.我们可以这样写: SELECT * FROM table where CONCAT(a,b,c......) like '%key%' 这样不就显得…
在使用MyBatis操作Oracle数据库的时候,写模糊查询突然发现原本在MySql中正确的代码,在Oracle中报错,参数个数无效 <if test="empId!=null and empId!=''"> and e.empId like CONCAT('%',#{empId},'%') </if> 异常信息: 经过查阅数个资料后得知Oracle的CONCAT函数不像MySql那样支持三个参数的拼接,需要把SQL语句修正为: and e.empId like…
1.使用两边加‘%’号的查询,oracle是不通过索引的,所以查询效率很低. 例如:select count(*) from lui_user_base t where t.user_name like '%cs%'; 2.like '...%'和 like'%...'虽然走了索引,但是效率依然很低. 3.有人说使用如下sql,他的效率提高了10倍,但是数据量小的时候 select count(*) from lui_user_base where rowid in ( select…