MySQL查询某个字段包含某个值--FIND_IN_SET

MySQL查询某个字段包含某个值--FIND_IN_SET,第1张

文章中有标签字段(label),存的是标签ID字符串。

现在想在文章列表进行筛选,根据标签筛选出对应标签的文章

但是不能用like。SO,FIND_IN_SET函数就大显身手了

FIND_IN_SET(str,strlist)

str 要查询的字符串

strlist 字段名 参数以”,”分隔 如 (1,2,6,8,10,22)

查询字段(strlist)中包含(str)的结果,返回结果为null或记录

倘若想搜索标签ID为2的文章:

SELECT id,label FROM dk_info where FIND_IN_SET ('2',label)

倘若想搜索标签ID为3的文章:

SELECT id,label FROM dk_info where FIND_IN_SET ('3',label)

update 表名 set 字段=(从本表查询出来的子查询)

where id = (从本表查询出来的ID)

但是需要保证子查询只有一条记录,并且只有一个字段

update a set flag='p' where flag is null

你这图片不是插入页吗?

如果你确定真没有值写入,首先查一下,你的set列中是否有'p'还是'P',更新完后可以用show warnings查看警告信息

补充:

很有可能你指的空值不是null,而是'',所以应该

update a set flag='p' where flag=''

尝试一下。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/7416570.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-05
下一篇 2023-04-05

发表评论

登录后才能评论

评论列表(0条)

保存