有个文章表里面有个type字段,他存储的是文章类型,有
1头条,2推荐,3热点,4图文
.....11,12,13等等
现在有篇文章他既是
头条,又是热点,还是图文,
type中以
1,3,4的格式存储.
那们我们如何用sql查找所有type中有4图文标准的文章呢,
这就要我们的find_in_set出马的时候到了.
先看mysql手册中find_in_set函数的语法:
FIND_IN_SET(str,strlist)
假如字符串str
在由N
子链组成的字符串列表strlist
中,则返回值的范围在
1
到
N
之间。一个字符串列表就是一个由一些被‘,'符号分开的自链组成的字符串。如果第一个参数是一个常数字符串,而第二个是type
SET列,则
FIND_IN_SET()
函数被优化,使用比特计算。如果str不在strlist
或strlist
为空字符串,则返回值为
0
。如任意一个参数为NULL,则返回值为
NULL。这个函数在第一个参数包含一个逗号(‘,')时将无法正常运行。
复制代码
代码如下:
mysql>
SELECT
FIND_IN_SET('b','a,b,c,d')
->
2
用起来很简单
就以上面我说到的情况来举例:
以下为引用的内容:
复制代码
代码如下:
select
*
from
article
where
FIND_IN_SET('4',type)
1、方法一:可以用%来实现。
比如:SELECT *FROM usersWHERE emailslike "%b@email.com%"。
2、方法二:利用mysql 字符串函数 find_in_set()
SELECT *FROM usersWHERE find_in_set('aa@email.com', emails)
要注意的是:mysql字符串函数 find_in_set(str1,str2)函数是返回str2中str1所在的位置索引,str2必须以","分割开。
3、方法三:多个值模糊查询,使用mysql正则:REGEXP。
此方式相当于( LIKE '%1%' OR LIKE '%3%' OR LIKE '%5%' )
SELECT * FROM `by_content` WHERE title REGEXP '(1|3|5)'。
扩展资料
mysql字符串函数:FIND_IN_SET()使用方法详解:
语法:
FIND_IN_SET(str,strlist)
第一个参数str是要查找的字符串。
第二个参数strlist是要搜索的逗号分隔的字符串列表。
假如字符串str 在由N 子链组成的字符串列表strlist 中,则返回值的范围在 1 到 N 之间。
一个字符串列表就是一个由一些被‘,’符号分开的子链组成的字符串。如果第一个参数是一个常数字符串,而第二个是type SET列,则 FIND_IN_SET() 函数被优化,使用比特计算。
如果str不在strlist 或strlist 为空字符串,则返回值为 0 。如任意一个参数为NULL,则返回值为 NULL。这个函数在第一个参数包含一个逗号(‘,’)时将无法正常运行。
要注意的是:mysql字符串函数find_in_set(str1,str2)函数是返回str2中str1所在的位置索引,str2必须以","分割开。用模糊查询,下述为转载:“SELECT
column
FROM
table
WHERE
column
LIKE
'pattern'”。1.
%
表示任意0个或多个字符。如下语句:将会把name为“张三”,“三脚猫”,“唐三藏”等等有“三”的全找出来;2.
_
表示任意单个字符。语句:3.
[
]
表示括号内所列字符中的一个(类似与正则表达式)。语句:4.
[^
]
表示不在括号所列之内的单个字符。语句:将排除“老1”到“老4”寻找“老5”、“老6”、……、“老9”。由于通配符的缘故,导致我们查询特殊字符“%”、“_”、“[”、“'”的语句无法正常实现,而把特殊字符用“[
]”括起便可正常查询。据此我们写出以下函数:关联UID,你根据你的情况做关联即可。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)