首页 > 数据库技术 > 详细

mysql 定位字符串的位置

时间:2017-06-27 14:24:04      阅读:3671      评论:0      收藏:0      [点我收藏+]

常用的一共有4个方法,如下:

1. 使用locate()方法

        1.1.普通用法:

              SELECT `column` from `table` where locate(‘keyword‘, `condition`)>0

         类似于 java 的 indexOf();不过 locate() 只要找到返回的结果都大于0(即使是查询的内容就是最开始部分),没有查找到才返回0;

        1.2. 指定其实位置:

               SELECT LOCATE(‘bar‘, ‘foobarbar‘,5);  --> 7 (从foobarbar的第五个位置开始查找)

2.使用instr()函数 (据说是locate()的别名函数)

       SELECT `column` from `table` where instr(`condition`, ‘keyword’ )>0

       唯一不同的是 查询内容的位置不同,见SQL语句中过的keyword

3.使用position()方法,(据说也是locate()方法的别名函数,功能一样) 

         SELECT `column` from `table` where position(‘keyword’ IN `condition`)

         不过它不再是通过返回值来判断,而是使用关键字 in

4.使用find_in_set()函数

       如: find_in_set(str,strlist),strlist必须要是以逗号分隔的字符串

    如果字符串str是在的strlist组成的N子串的字符串列表,返回值的范围为1到N

SQL> SELECT FIND_IN_SET(‘b‘,‘a,b,c,d‘);
+---------------------------------------------------------+
| SELECT FIND_IN_SET(‘b‘,‘a,b,c,d‘)                       |
+---------------------------------------------------------+
| 2                                                       |
+---------------------------------------------------------+
1 row in set (0.00 sec) 

转自:http://www.cnblogs.com/tommy-huang/p/4483583.html

mysql 定位字符串的位置

原文:http://www.cnblogs.com/liu-shiliu/p/7084719.html

(0)
(0)
   
举报
评论 一句话评论(0
分享档案
最新文章
教程昨日排行
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!