mysql 中的set

mysql 中的set,第1张

set是修改系统参数或者设置变量用的,例如:

-- 设置字符集为utf8

set GLOBAL character_set_server='utf8'

-- 设置变量等于某个值

set @d=11

select @d  -- 此处可查到d的值为11

mysqlset类型是5.6版本。mysqlset函数原型是intmysql_set_character_set(MYSQL*mysql,char*csname)。该函数用于为当前连接设置默认的字符集。字符串csname指定了1个有效的字符集名称。连接校对成为字符集的默认校对。该函数的工作方式与SETNAMES语句类似,但它还能设置mysql->charset的值,从而影响了由mysql_real_escape_string()设置的字符集。该函数是在MySQL5.0.7中增加的。该函数0表示成功,非0值表示出现错误。

文章中有标签字段(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)


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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存