头歌-第1关:多表查询(数据库实验三 数据查询二)

任务描述

本关任务:查询来自借阅、图书、读者数据表的数据 为了完成本关任务,你需要掌握:

如何多表查询

相关知识

查询多个数据表

在实际应用中,查询经常会涉及到几个数据表。 基于多个相关联的数据表进行的查询称为连接查询。

命令格式: select * from 数据表 from 数据表1,数据表2 where 连接条件

对于连接查询,在FROM短语后多个数据表的名称之间用逗号隔开,在WHERE短语中须指定数据表之间进行连接的条件 在连接查询中引用两个表的公共字段时,必须在字段前添加表名作为前缀,否则系统会提示出错。 对于只在一个数据表中出现的字段,则无需指定前缀。

第二种方法 from 数据表1 join 数据表2 on 连接条件 数据表1和数据表2为需要连接的数据表 on后面是连接的条件 通常是关键字段的值相同

三个表的查询 如果要实现三个表的查询,可以 From 数据表1 ,数据表2 ,数据表3 where 连接条件1 and 连接条件2

任务要求

打开library数据库 第一题 根据读者(reader)和借阅(borrow)数据表,查询王颖珊的借阅记录,包括条形码txm、借阅日期jyrq、还书日期hsrq 第二题 根据图书(book)和借阅(borrow)数据表,查询李白全集被借阅的情况:包括读者证号dzzh、借阅日期jyrq、还书日期hsrq 第三题 根据读者(reader)、图书(book)和借阅(borrow)数据表查询没有被归还的借阅信息:包括读者证号dzzh、姓名xm、电话dhhm、条形码txm、书名sm、借阅日期jyrq 提示:通过isnull(表达式)可以判断表达式是否NULL值

 use library;
-- select * from borrow;
-- select *from reader;
-- select *from book;
--  #代码开始
--  #第一题
select borrow.txm,borrow.jyrq,borrow.hsrq
from borrow join reader 
on reader.dzzh = borrow.dzzh
where reader.xm='王颖珊';

-- --  #第二题
select borrow.dzzh,borrow.jyrq,borrow.hsrq
from borrow join book 
on borrow.txm=book.txm
where book.sm='李白全集';
--  #第三题
select reader.dzzh,xm,dhhm,book.txm,sm,jyrq 
from book join borrow 
on book.txm=borrow.txm join reader
on reader.dzzh=borrow.dzzh
where isnull(hsrq); 
--  #代码结束

  • 7
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值