find_in_set - 请教 mysql查询
问题描述
mysql 表中字段option_tag 存储的值格式(分号)为: 4:539;8:543;4:545;8:549通过 find_in_set() 可以查找到以逗号分隔的字符串。以分号分隔的 字符串 有什么函数直接能查询到 option 含有 539的所有值?

问题解答
回答1:sql语句:SELECT * FROM tableWHERE locate(’:539;’, CONCAT(options_tag, ’;’)) > 0
用like的方法逻辑上不严谨,如4:2539这种情况也会被like匹配,但不是想要的结果。
从设计方案考虑,如果是复杂的数据类型,建议存成json格式,mysql高版本直接内置了json解析、查询功能。
回答2:通过like或者正则即可。但是不建议将逻辑放在mysql中,造成数据库引擎压力过大,而且极度不安全。正确的做法应该是把整个字段的值取出来,作为字符串然后用语言比如php python nodejs之类的处理。
回答3:SELECT * FROM tableWHERE options_tag LIKE ’%539%’;
正如@小虫哥哥 所说,这是设计缺陷,这看起来是一个一对多或者多对多的关系,不应该用一个字段存起来,不仅查询效率低(在SQL里对字段进行运算有可能会使该字段的索引无法被使用),而且查询起来也不灵活。
回答4:like 匹配
回答5:like :539
回答6:我说这是设计缺陷有人赞同吗
回答7:like相似匹配
回答8:模糊查询研究下
相关文章:
1. python 多进程 或者 多线程下如何高效的同步数据?2. windows-7 - win7下使用cmder,如何设置vim的tab为4个空格?3. web - nginx location 搜索算法问题!?4. media-query - 请教为何CSS3媒体查询语法不能生效?5. thinkPHP5中获取数据库数据后默认选中下拉框的值,传递到后台消失不见。有图有代码,希望有人帮忙6. python - 怎么进行服务器性能分析7. javascript - 关于js高级程序中的问题8. MySQL的SELECT...FOR UPDATE究竟起什么作用9. javascript - nodejs使用mongoose连接数据库,使用post提交表单在后台,后台处理后调用res.redirect()跳转界面无效?10. mysql - 要取出数据库中按某字段排序后的前10,20,30条数据要怎么做?

网公网安备