MySQL中有关会议室表的练习

现有一个会议室管理系统,有一张会议室表(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';

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL查询是指在查询同时涉及到多个的操作。多查询可以更加方便地获取到需要的数据,提供了更加灵活的查询方式。 在进行多查询之前,我们首先需要对多个之间的关系进行了解和分析。常见的多查询方式包括联接查询、子查询以及多级嵌套查询等。 联接查询是最常见且常用的多查询方式之一。通过联接查询,我们可以根据两个或多个之间的关联字段,将它们连接在一起进行查询。 例如,我们有两个A和B,它们通过一个共同的字段关联起来。我们可以使用联接查询语句如下: SELECT A.field1, B.field2 FROM A INNER JOIN B ON A.common_field = B.common_field; 在这个查询,我们使用了INNER JOIN关键字将A和B连接起来,其common_field是两个之间的关联字段。通过这个联接查询,我们可以同时获取到A和B的相关信息。 除了联接查询之外,我们还可以使用子查询和多级嵌套查询进行多查询。 子查询是指在查询语句嵌套了另一个查询语句。通过子查询,我们可以在一个查询引用另一个查询的结果作为条件进行查询。 多级嵌套查询是指在一个查询语句嵌套了多个子查询。通过多级嵌套查询,我们可以按照一定的顺序和逻辑进行复杂的查询操作。 综上所述,MySQL查询是一种可以同时涉及多个进行查询的操作。通过联接查询、子查询和多级嵌套查询等方式,我们可以更加灵活地获取到需要的数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值