我在Select查询中使用WHERE时出现问题。 DB表包含一个字段,用于存储数据除以“1,2,3”之类的逗号。 我不知道如何检查该字段是否包含1,2或3.通常的查询将是 “SELECT * FROM”。$ table。“WHERE name ='”。$ val。“'”。 但是当然这只找到等于$ val的条目,所以如果我搜索“1”,它只会给我只包含“1”的条目,而不是“1,2,3”或“1,2”。有没有办法做到这一点?
谢谢你们
答案 0 :(得分:4)
您应该修复数据结构。有很多理由避免将数字列表存储为字符串:
有时,我们会遇到其他人非常糟糕的设计决策。在这些情况下,MySQL提供find_in_set()
:
where find_in_set(1, name) > 0