博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql 定位字符串的位置
阅读量:6232 次
发布时间:2019-06-21

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

mysql中没有charinde,使用find_in_set又只能定位逗号隔开的字符串位置,如果想查指定字符串中是否存在一个指定的字符,除了用like+count(1)以外,还可以考虑用

locate,position,instr函数,具体使用方法:

 

常用的一共有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

转载于:https://www.cnblogs.com/liu-shiliu/p/7084719.html

你可能感兴趣的文章
mysql将查询到的数据导出到Excel
查看>>
Android 切换系统语言源码分析
查看>>
API 调用次数限制实现
查看>>
我的网站搭建 (第十八天) 自定义用户模型
查看>>
排序应该在数据库还是在应用程序中进行?
查看>>
java过滤特殊字符的正则表达式,正则表达式学习
查看>>
VM VirtualBox安装CentOS 7 64位实践
查看>>
如何搭建一个独立博客——简明Github Pages与Hexo教程
查看>>
OC中Category的注意点
查看>>
OC中的布局-九宫格
查看>>
JAVA网络编程:计算机原理学习
查看>>
ARouter解析三:URL跳转本地页面源码分析
查看>>
git 常用操作
查看>>
iReport 中创建JavaBeanDataSource,用java类提供数据源给iReport
查看>>
大数据时代下的生活
查看>>
spring定时任务(方便轻巧)
查看>>
iOS的主要框架介绍
查看>>
spring源码阅读笔记(一)
查看>>
Selenium的简单安装和使用
查看>>
ios 滤镜
查看>>