文章详情页
Mysql 有啥方法 能够查询 一个串在另一个串里面
浏览:46日期:2022-06-06 18:32:28
问题描述
Mysql 有啥方法 能够查询 例如 '3,5' 这个串, 是在 '3,4,5,2'串 内
情况 大概是这个
用户有多个属性, 属性ID是在用户表 用一个字段存储
如user_attr,值存储格式为:'3,4,5,2',
解释下:例如 数字就是 属性ID
现在前端需要查询 同时具有多个属性的用户
如 前端传过来需要查询的属性ID格式为 : '3,5' ,字符串的格式
我该怎么写查询呢,我用的thinkphp5, <<in,like 这些我试过都不行>>
问题解答
回答1:find_in_set() 了解下
回答2:like正解回答3:这里不需要用sql查询,将前端传递来的3,5 转为数组[3,5] ,然后 3,4,5,2也转为数组,对比一下就知道在不里面了
回答4:把3,5转换为数组,循环拼接where条件,user_attr like '%3%' or user_attr like '%5%' groug by 用户id呢?可能效率没有那么高,可以实现
相关文章:
1. 微信小程序如何将获取的时间戳提交到数据库?2. node.js - 微信的自动回复问题3. python - Scrapy中xpath用到中文报错4. mysql - spring data jpa 方法sql复杂查询?5. mysql - 为什么innodb下更新A行时B行也被锁住?6. node.js - nodejs中mysql子查询返回多行结果怎么处理?7. python - 如何给模块传参数,参数是模块的函数名?8. 请问python中为什么我用for循环对嵌套列表进行赋值时,都是以i的最终值来计算的?9. linux - python编译ssl错误10. javascript - 我写的href跳转地址不是百度,为什么在有的机型上跳转到百度了,有的机型跳转正确
排行榜