mysql - 数据库JOIN查询
问题描述
问题解答
回答1:drop table if exists article;drop table if exists category;drop table if exists r_ac;create table article(id serial not null,title varchar(100),expire timestamp,primary key(id));create table category(id serial not null,name varchar(50),primary key(id));create table r_ac(article int not null,category int not null,primary key(article, category));insert into article(title, expire) values (’a’, ’2017-05-20’),(’b’, null),(’c’, ’2017-03-04’),(’d’, ’2017-02-23’),(’e’, ’2017-04-23’),(’f’, ’2016-09-15’),(’g’, ’2017-06-09’);insert into category(name) values (’c1’),(’c2’),(’c3’),(’c4’),(’c5’),(’c6’),(’c7’);insert into r_ac (article, category) values(1, 1), (1, 2), (1, 5), (1, 7),(2, 1), (2, 6),(3, 5),(4, 1), (4, 4),(7, 1), (7, 7);select category, c.name, count(1) as c from r_ac as acinner join (select id, title, expire from article where expire is null or expire>now()) as z on ac.article=z.idleft join category as c on ac.category=c.idgroup by category, c.name;回答2:
select c.id,count(a.id) from category c LEFT JOIN r_ac r on r.category=c.idLEFT JOIN article a on a.id=r.article and ifnull(a.expire>NOW(),1)GROUP BY c.id
相关文章:
1. javascript - vue使用videojs+videojs-contrib-hls报错2. javascript - layer 弹窗嵌入iframe,子页面中元素怎么实现点击关闭layer弹窗?3. 关于phpstudy设置主从数据库4. docker内创建jenkins访问另一个容器下的服务器问题5. dockerfile - [docker build image失败- npm install]6. (python)关于如何做到按win+R再输入文件文件名就可以运行?7. java - 接口中的成员变量怎么不是常量了?8. javascript - 求救!网页播放视频只有声音没有画面,网页上传视频文件时怎么知道视频的编码为H264还是MPEG4??9. mysql如何配置远程php外网链接数据库10. angular.js - angular 配置代理proxy.conf.json后报错,页面返回500internal server error?
