mysql一条查询语句。
ringa_lee
ringa_lee 2017-04-17 13:43:47
[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语句。

ringa_lee
ringa_lee

ringa_lee

全部回复(4)
高洛峰

第一种:

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,%' ;
这样应该可以
PHPz
find_in_set('1',tags) 就好
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号