多对多的查询,三表查询,求mysql语句
程序员文章站
2022-06-11 10:28:45
...
普通应用:文章和标签的数据表,然后查询某个标签,如“技术”,能够查询出所有技术类的文章。
文章表article:
标签表tags:
文章标签关系表art_tags:
然后根据标签搜索关键词“技术”,应该显示1、3、4这三篇文章
at.tid=2 ? 这个没法事先得知的啊。用户输入的是汉字“技术”
文章表article:
aid, title,content-----------------------------------------1 Qt助力跨平台应用开发,势不可挡2 Qt助力跨平台应用开发,势不可挡3 Qt助力跨平台应用开发,势不可挡4 Qt助力跨平台应用开发,势不可挡
标签表tags:
tid,tname--------------------------------1 生活2 技术3 科技4 娱乐
文章标签关系表art_tags:
aid,tid----------------------------1 11 21 32 12 32 43 13 23 44 14 2
然后根据标签搜索关键词“技术”,应该显示1、3、4这三篇文章
回复讨论(解决方案)
select a.* from article as a left join art_tags at on at.aid=a.aid where at.tid=2
select a.* from article as a left join art_tags at on at.aid=a.aid where at.tid=2
at.tid=2 ? 这个没法事先得知的啊。用户输入的是汉字“技术”
select * from article where aid in(select aid from art_tags where tid in(select tid from tags where tname='技术'));
select a.* from article a left join art_tags b on a.aid=b.aid left join tags c on c.tid=b.tid where b.tname='技术'
谢谢!
原来where也可以这么写
上一篇: html中的 标签以及禁用方法介绍
下一篇: php adodb分页实现代码
推荐阅读
-
MySQL 多表关联一对多查询实现取最新一条数据的方法示例
-
多对多的查询,三表查询,求mysql语句
-
MySQL数据库学习笔记3.0对数据库表中数据的操作、DQL查询语句
-
Java 框架 04 — MyBatis_03(连接池和事务的深入、动态sql语句、多表查询_1对1_1对多_多对多)
-
mybatis连接池,动态的Sql语句,多表查询一对多,多对多
-
MySQL 多表关联一对多查询实现取最新一条数据的方法示例
-
DJango 多表操作:一对一、一对多、多对多的增删改,基于对象/双下划线的跨表查询
-
求一条三表关联查询的MySQL语句
-
求一条三表关联查询的MySQL语句
-
MySQL实现一对多查询的代码示例