SQL中instr和like的使用区别
1、instr函数
instr函数是一个字符串处理函数,它在Oracle/PLSQL中是返回子字符串在源字符串中的位置,如果在源串中没有找到子串,则返回0。
instr函数定义如下:
/* * 返回子字符串在源字符串中的位置(字符串位置从1开始,而不是从0开始) * @param str 源字符串 * @param substr 子字符串 * @param position 检索位置,可省略(默认为1),参数为正时,从左向右检索,参数为负时,从右向左检索 * @param occurrence 检索子串出现次数(即子串在源串第几次出现),可省略(默认为1),值只能为正整数,否则会报错 * @return 返回子字符串在源字符串中出现的位置(没找到返回0) */ instr(str, substr, position, occurrence);
例如:
SELECT INSTR('hello world', 'l') FROM DUAL; --结果:3 SELECT INSTR('hello world', 'l', 5) FROM DUAL; --结果:10 (从左向右第5位开始检索'l'在'hello world'中出现的位置) SELECT INSTR('hello world', 'l', -1) FROM DUAL; --结果:10 (从右向左第1位开始检索'l'在'hello world'中出现的位置) SELECT INSTR('hello world', 'l', 2, 2) FROM DUAL; --结果:4 (从左向右第2位开始检索'l'在'hello world'中第2次出现的位置) SELECT INSTR('hello world', 'l', -3, 3) FROM DUAL; --结果:0 (从右向左第3位开始检索'l'在'hello world'中第3次出现的位置)
2、like关键字
like关键字也可称为通配符,在SQL中用于模糊查询。可以使用“%”和“_”通配符,其中“%”代表0个或多个字符,“_”代表1个字符。
例如:
SELECT * FROM STUDENTTAB WHERE STUNAME LIKE '%张%'; --在STUDENTTAB表中查询STUNAME中含有字符“张”的学员 SELECT * FROM STUDENTTAB WHERE STUNAME LIKE '张_'; --在STUDENTTAB表中查询STUNAME中以“张”开头,名字长度为2的学员(即“张三”、“张四”,而不会检测出“张三三”)
3、instr和like的使用:
SELECT * FROM STUDENTTAB WHERE STUNAME LIKE '%张%'; 就相当于 SELECT * FROM STUDENTTAB WHERE INSTR(STUNAME, '张') > 0; SELECT * FROM STUDENTTAB WHERE STUNAME NOT LIKE '%张%'; 就相当于 SELECT * FROM STUDENTTAB WHERE INSTR(STUNAME, '张') = 0;
4、总结
(1)instr>0 和like、instr=0 和not like 一般来说查询的结果相同(不考虑特殊字符)
(2) instr是一个函数,可以建立函数索引,如果过滤的条件有索引,那么instr就可以提高性能。
(3) like查询时,以'%'开头,列所加的索引是不起作用的。
(4) 在没有索引的前提下,当数据量比较大时,instr要比like效率高。
原文:https://blog.csdn.net/lanmuhhh2015/article/details/79216804
PS:LIKE 和 RLIKE 的区别:
LIKE
语法格式为A [NOT] LIKE B,B是sql下的简单正则表达式,也叫通配符模式,如_匹配一个字符,%可以匹配任意多个字符,A会对表达式B做匹配,如果通过返回TRUE,如果不通过则返回FALSE,举个栗子
SELECT name LIKE ‘%Alice’ FROM table1,表示选择name列内以ALICE作为结尾的数据
RLIKE
语法格式为A [NOT] RLIKE B,基于java的正则表达式接口实现,如果A中有与B匹配则返回TRUE,否则返回FALSE,java的正则表达式相信大家都比较熟悉就不举具体的例子了
区别
通配符匹配的是整个列,比如helloworld就无法和’world’通配,但是正则表达式则是在列值内进行匹配,helloworld就可以和’world’匹配返回TRUE
另外,引入RLIKE该操作符的目的是引入正则表达式这样一个更加强大的语言来匹配条件,举个简单的对比例子
A RLIKE '.*(Alice|Ben).*'
匹配包含Alice或者Ben的字段,使用LIKE的话需要用两个LIKE来做组合,下面是使用LIKE改成相同效果
A LIKE '%Alice%' OR A LIKE '%Ben%'
原文:https://blog.csdn.net/u013019431/article/details/78491037
相关文章
- ORA-13842: no SELECT privilege on DBA_SQL_PROFILES ORACLE 报错 故障修复 远程处理
- SQL Server数据类型char、nchar、varchar、nvarchar的区别浅析
- 带例子详解Sql中Union和Union ALL的区别
- SQL Server数据库定时自动备份
- MySQL防止SQL注入的过滤方法(mysql过滤注入)
- Oracle 参数 OPTIMIZER_USE_SQL_QUARANTINE 官方解释,作用,如何配置最优化建议
- MySQL 与 SQL: 两者的区别(mysqlsql区别)
- 掌握SQL语句, 打开Oracle大门(sql语句oracle)
- MongoDB实现“SQL NoSQL”合一(mongodb支持sql)
- SQL与Oracle在数据库中的区别(sql和oracle区别)
- 互联网时代信息管理之SQL Server(互联网sqlserver)
- SQL Server:可持续优化的数据库利器(sqlServer的名称)
- SQL Server中的死锁:如何预防与解决(sqlserver死循环)
- SQL Server架构师:拥抱数据的未来(sqlserver架构师)
- SQL Server:不断改善的语言技术(sqlserver 发音)
- Oracle大法师:多条SQL串联,效率倍增!(oracle多条sql)
- SQL Server 数据值替换的奇妙之处(sqlserver值替换)
- SQL与MySQL的异同——引起关注的相似之处(sql和mysql的区别)
- Oracle如何利用SQL快速写出时间表达式(oracle写时间sql)
- MySQL实现两条 SQL 拼接操作(mysql两条sql拼接)
- 语句Oracle推出新SQL语句 助你工作更高效(oracle会新增sql)
- oracle与SQL 背后的不同(oracle与sql区别)
- 学习 Oracle SQL实战案例分享(oracle sql案例)
- Oracle SQL 分类整理技巧(oracle sql归类)