现有一个会议室管理系统,有一张会议室表(id,名称,位置,大小,投影),一张预定表(id,会议室id,起始时间,结束时间,预定人)建表语句如下:
create table meeting(
id int(11) not null auto_increment,
name varchar(50) default '',
position varchar(256) default '',
size int(11) default 0, projection int(11) default 1,
primary key(id)) engine=innodb default charset=utf8mb4;
create table booking(
id int(11) not null auto_increment,
meeting_id int(11) not null,
start_time datetime default now(),
end_time datetime default now(),
booking_man varchar(50) default 'admin',
primary key(id)
) engine=innodb default charset=utf8mb4;
题目一:请写SQL语句查出哪个会议室本月被预定次数最多。提示:可以该变表结构,给表增加计算列
正确答案:alter table booking add column y_m varchar(10) default '201907'; select m.name, count(1) from booking b left join meeting m on m.id = b.meeting_id group by meeting_id, y_m having y_m='201907';
题目二:请写SQL语句查出哪些人预定会议室最频繁。
正确答案:`select booking_man, count(1) from booking b group by booking_man;
题目三:请写SQL语句查出7月1日上午11:00,哪些会议室已经被预定。
正确答案:select b.booking_man,b.start_time,b.end_time,m.name,m.projection from booking b left join meeting m on b.meeting_id=m.id where b.start_time<='2019-07-01 11:00:00' and b.end_time>'2019-07-01 11:00:00';