博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
sql instr()与LOCATE()字符串查找函数
阅读量:5969 次
发布时间:2019-06-19

本文共 1011 字,大约阅读时间需要 3 分钟。

  hot3.png

由于今天一网站的子分类用到了关于sql instr()与LOCATE()字符串操作函数,下面做个笔记放下来,有需要的朋友可以参考一下。

INSTR(str,substr) 

返回字符串 str 中子字符串的第一个出现位置。这和LOCATE()的双参数形式相同,除非参数的顺序被颠倒。 

 代码如下 复制代码
> SELECT INSTR('foobarbar', 'bar');
        -> 4
mysql> SELECT INSTR('xbar', 'foobar');
        -> 0

LOCATE(substr,str) , LOCATE(substr,str,pos) 
第一个语法返回字符串 str中子字符串substr的第一个出现位置。第二个语法返回字符串 str中子字符串substr的第一个出现位置, 起始位置在pos。如若substr 不在str中,则返回值为0。

 代码如下 复制代码
mysql> SELECT LOCATE('bar', 'foobarbar');
        -> 4
mysql> SELECT LOCATE('xbar', 'foobar');
        -> 0
mysql> SELECT LOCATE('bar', 'foobarbar',5);
        -> 7

这个函数支持多字节字元,并且只有当至少有一个参数是二进制字符串时区分大小写。

POSITION(substr IN str) 
返回子串 substr 在字符串 str 中第一次出现的位置。如果子串 substr 在 str 中不存在,返回值为 0:

 代码如下 复制代码
mysql> SELECT POSITION('bar', ‘foobarbar'); 
-> 4 
mysql> SELECT POSITION('xbar', ‘foobar'); 
-> 0

效率测试

 代码如下 复制代码

SELECT * FROM `o_soft` WHERE LOCATE('d200',tid2)>0

MySQL 返回的查询结果为空(即零行)。 (查询花费 0.0050 秒)

 代码如下 复制代码

SELECT * FROM `o_soft` WHERE INSTR('d200',tid2)>0

MySQL 返回的查询结果为空(即零行)。 (查询花费 0.0009 秒)

转载于:https://my.oschina.net/liting/blog/475670

你可能感兴趣的文章
转:ECharts图表组件之简单关系图:如何轻松实现另类站点地图且扩展节点属性实现点击节点页面跳转...
查看>>
开发kendo-ui弹窗组件
查看>>
[LeetCode] Single Number 单独的数字
查看>>
Android——Intent动作汇总(转)
查看>>
Android根据baidu Android定位SDK实现定位
查看>>
thinkphp 3.2跟3.1 区别
查看>>
智能手机屏幕尺寸和分辨率一览表
查看>>
【转】每天一个linux命令(50):crontab命令
查看>>
IOS中UITableView异步加载图片的实现
查看>>
sencha touch Model validations 自定义验证 二选一输入验证、重复验证、时间验证、比较验证、条件验证(2015-1-14)...
查看>>
javascript的实现事件的一些实例
查看>>
opencv第一课 打开一个图片
查看>>
二分查找
查看>>
linux目录结构
查看>>
adb无线网络调试
查看>>
java.lang.ClassCastException
查看>>
YbSoftwareFactory 代码生成插件【二十二】:CMS基础功能的实现
查看>>
linux系统调用和库函数调用的区别
查看>>
怎样一步一步删除(linux & UNIX)环境下 oracle 11g 集群节点
查看>>
排序算法
查看>>