首页 > mysql一条查询语句。

mysql一条查询语句。

访问的url:
http://www.xxx.com/list.php?tag=1
数据库中有个tag的字段
存的数据都是(1,2,3),(2,22,44),(1,22,11),(1),(1,23)(22,33)。这个是六条数据,没有括号。

我想获取数据中有1那个那个文章,把他查询出来。
我想到的方法

SELECT * FROM article WHERE tags like "%1%";
SELECT * FROM article WHERE find_in_set('1', tags);

但是感觉有问题。有没有类似于

SELECT * FROM article WHERE id=1

类似的SQL语句。


find_in_set('1',tags) 就好

第一种:

SELECT * FROM `article` WHERE `tags` like "%1%" or `tags` like '1%' or `tags` like '%1';

第二种:

SELECT * FROM `article` where `tags` regexp '1';
#可能存在低版本perl库不支持regexp的情况

第三种:
你的数据库设计不合理,应该用新的表存储tags与文章的关系


一般好像 要么像你这样 用一个字段存多个id,要么就建一个关联表。

另外我觉得你的like查询会有问题,13和123都会被查到


SELECT * FROM article concat(',', tag, ',') like '%,1,%' ;
这样应该可以
【热门文章】
【热门文章】