数据库SQL语言实战(五)(数据库系统概念第三章练习题)

这篇具有很好参考价值的文章主要介绍了数据库SQL语言实战(五)(数据库系统概念第三章练习题)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

前言知识

一、 关系模式

二、 属性域

例子

介绍

作用

三、Select常数

举例

解释 

四、集合差运算

本质

举例 

结论

练习题

3.17

3.18 

3.21 

总结 


注:本文的SQL语言适用的是Oracle数据库与mySQL可能存在略微不同

前言知识

一、 关系模式

  1. 模式的定义:模式则是指数据库中所有关系模式的集合,它代表了整个数据库的结构。模式不仅包含了所有的关系模式,还可能包括视图、索引等其他数据库对象的定义。模式是数据库的整体架构,它定义了数据库中数据的组织方式和存储结构
  2. 关系模式定义:关系模式可以被看作是数据库中表的蓝图或框架,它定义了表的结构,包括表的属性(即列)和每个属性上的约束条件。它是静态的定义,不随表中数据的变化而变化。关系模式通常使用五元组来表示,包含关系名、属性集合、属性对应的域、属性到域的映射以及属性间的依赖关系

关系模式:表示一张基本表上的所有因素(属性、属性域、属性关系等)

模式:表示整个数据库的结构,是一组基本表的集合

二、 属性域

例子

CREATE DOMAIN age_domain  as INTEGER
    CHECK (value >= 0 AND value <= 150)
    NOT NULL;

创建了一个age_domain,这个域是整形的,数值在0-150之间 且不能为空

介绍

域本身可以理解为一个特殊的变量类型,这个变量类型包括最基础的变量类型也包括变量的约束、限制等。定义完域后,我们可以在定义表中属性时直接使用属性域。如下:

CREATE TABLE person (
    id char(10) PRIMARY KEY,
    name VARCHAR(50),
    age age_domain
);

 作用

  1. 提高数据一致性:通过为用户自定义数据类型添加约束,可以确保数据库中的数据满足特定的条件,从而维护数据的一致性和准确性。
  2. 简化数据类型管理:当需要对多个表或列应用相同的数据类型和约束时,用户自定义域可以减少重复代码,使数据库管理更加简洁高效。
  3. 促进代码重用:一旦定义了域,就可以在数据库中的任何表或列上重复使用它,这有助于保持数据类型的统一性和标准化。

三、Select常数

举例

select 2
from employee

 结果为:

数据库SQL语言实战(五)(数据库系统概念第三章练习题),数据库,数据库,sql,oracel

解释 

1、select x from employee:在数据库中直接显示x这个数构成的元组,个数为employee中记录的个数

四、集合差运算

本质

A-B:A中有B中没有。在A中减掉B的部分

举例 

-- 创建集合A和B的表
CREATE TABLE set_a (id INT);
INSERT INTO set_a (id) VALUES (1), (2), (3);

CREATE TABLE set_b (id INT);
INSERT INTO set_b (id) VALUES (1), (4);

-- 计算A减去B的结果
SELECT a.id
FROM set_a a
LEFT JOIN set_b b ON a.id = b.id
WHERE b.id IS NULL;

所得到的结果为:

 id
---
 2
 3

 结论

集合差运算中B中有A中没有的部分对结果不产生影响

练习题

3.17

考虑图 3.19 中的雇员数据库。用 SQL 语句给出表达式

数据库SQL语言实战(五)(数据库系统概念第三章练习题),数据库,数据库,sql,oracel

a. 给 "第一银行公司 "的所有员工加薪 10%

update works as T
set T.salary=T.salary*1.1
where company_name='First Bank Corporation'

b. 给 "第一银行公司 "的所有经理加薪 10%

update works as T
set T.salary=T.salary*1.1
where company_name='First Bank Corporation'
and T.id in(
  select id
  from manages
)

c. 删除 "小型银行公司 "员工在works关系中的所有元组

delete from works
where company_name='Small Bank Corporation'

3.18 

给出图 3.19 中雇员数据库的 SQL 模式定义。为每个属性选择一个适当的域,为每个关系模式选择一个适当的主键。为每个关系模式选择适当的域和主键。包括任何可能合适的外键约束。适当的外键约束

数据库SQL语言实战(五)(数据库系统概念第三章练习题),数据库,数据库,sql,oracel

create domain company_names char(20)
create domain person_names char(20)
create domain city_names char(30)

create table employee(
  person_name person_names,
  street char(30),
  city city_names,
  ID char(4),
  primary key(ID)
)
create table works(
  ID char(4),
  company_name company_names,
  salary int(8),
  foreign key(ID) references employee(ID),
  foreign key(company_name) references company(company_name)
)
create table company(
  company_name company_names,
  city city_names,
  primary key(company_name)
)
create table manages(
  ID char(4),
  manager_id char(4)
  foreign key(id) references employee(id)
)

3.21 

考虑图 3.20 中的图书馆数据库,用 SQL 编写以下查询

数据库SQL语言实战(五)(数据库系统概念第三章练习题),数据库,数据库,sql,oracel

a. 找出每位至少借过一本“麦格劳-希尔”出版的书的会员的编号和姓名

select memb_no,name
from member
where memb_no in(
  select memb_no
  from book bk,borrowed bw
  where bk.isbn=bw.isbn
  and publisher='McGraw-Hill'
)

b.找出每一位借过“麦格劳-希尔”出版的所有书的会员的编号和姓名

select memb_no,name
from member m
where no exists(
  (
    select isbn
    from book bk
    where publisher='McGraw-Hill'
  )
  minus
  (
    select isbn
    from borrowed bw
    where m.memb_no=bw.memb_no
  )
)

c.对于每个出版商,找出每个借了该出版商五本书以上的会员的编号和姓名

select memb_no,name
from member m
where memb_no in(
  select memb_no
  from borrowed bw,book bk
  where bw.isbn=bk.isbn
  group by publisher,memb_no
  having (count(*)>5)
)

d.找出每位会员的平均借书量。考虑到如果一个成员没有借阅任何书籍,那么该成员根本不会出现在借阅关系中,但该成员仍然计算在平均值中

select(
  (select count(*)
  from borrowed)/
  (select count(*)
  from member)
)

总结 

本文的所有题目均来自《数据库系统概念》(黑宝书),不可用于商业用途转发。

如果能帮助到大家,大家可以点点赞、收收藏呀~ 

数据库SQL语言实战(五)(数据库系统概念第三章练习题),数据库,数据库,sql,oracel文章来源地址https://www.toymoban.com/news/detail-855216.html

到了这里,关于数据库SQL语言实战(五)(数据库系统概念第三章练习题)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 开源数据库MYSQL DBA运维实战 第三章 备份

    丢/删 1.数据的一致性 2.服务的可用性 3.1物理备份/冷备份 直接复制数据库文件,适用于大型数据库环境,不受存储引擎的限制,但不能恢复到不同的mysql tar,cp,scp 拷贝数据,有点快,缺点服务停止 3.2逻辑备份/热备份 备份的是建表,建库,插入等操作所执行SQL语句(DDL,DML,D

    2024年02月21日
    浏览(103)
  • 数据库系统概论—标准语言SQL

    1.1基本表的定义、删除与修改 定义基本表 修改基本表 删除基本表 CASCADE:与其相关的全部删除,比如视图,索引等 RESTRICT:如果有依赖关系或是建立索引等,就不删除 但是不同的数据管理系统的执行不同 1.2索引的建立与删除 建立索引 删除索引 基本结构 2.1单表查询 利用上

    2023年04月24日
    浏览(72)
  • 数据库系统工程师——第三章 数据结构与算法

    数据结构是指 数据元素的集合 及 元素间的相互关系和构造方法 ,结构就是元素之间的关系。在数据结构中,元素之间的相互关系是数据的逻辑结构。按照逻辑关系的不同将数据结构分为线性结构和非线性结构,其中,线性结构包括线性表、栈、队列、串,非线性结构主要包

    2024年02月04日
    浏览(66)
  • 【MySQL】:探秘主流关系型数据库管理系统及SQL语言

    🎥 屿小夏 : 个人主页 🔥个人专栏 : MySQL从入门到进阶 🌄 莫道桑榆晚,为霞尚满天! 在现代信息技术领域中,数据库管理系统扮演着至关重要的角色。本文将介绍数据库、数据库管理系统和SQL等概念,并深入探讨主流的关系型数据库管理系统以及关系型数据库的数据模

    2024年01月20日
    浏览(69)
  • 数据库系统头歌实验一 SQL的DDL语言和单表查询

    第1关:创建供应商表S(SNO,SNAME,STATUS,CITY) 供应商表S由供应商代码(SNO)、供应商姓名(SNAME)、供应商状态(STATUS)、供应商所在城市(CITY)组成;S表如下 第2关:将P表中的所有红色零件的重量增加6。 零件表P由零件代码(PNO)、零件名(PNAME)、颜色(COLOR)、重量(WEIGHT)组成;

    2024年02月07日
    浏览(51)
  • SQL Server数据库基本概念

    目录 一.SQL Server数据库基本构成 1.数据 2.数据库管理系统和数据库系统  二.经典的数据模型 三.常用的主流数据库 四.主键与外键 五.数据完整性规则 描述事物的符号记录称之为数据(Date),数据不仅仅包括数字、文字、图形、图像、声音、档案记录等都是数据。在数据库中,数

    2024年02月07日
    浏览(70)
  • 数据库基本概念和SQL基本语句

    数据库(Database)是按照数据结构来组织、存储和管理数据的仓库。在数据库中,数据通常以表格的形式存储,这些表格包含了行和列。行通常代表记录,而列代表记录中的不同字段。数据库的设计允许对数据进行高效地查询、更新、删除和添加操作。 基本概念: 数据(Da

    2024年04月22日
    浏览(52)
  • 【SQL Server】数据库开发指南(一)数据库设计的核心概念和基本步骤

    本系列博文还在更新中,收录在专栏:#MS-SQL Server 专栏中。 本系列文章列表如下: 【SQL Server】 Linux 运维下对 SQL Server 进行安装、升级、回滚、卸载操作 【SQL Server】数据库开发指南(一)数据库设计的核心概念和基本步骤 【SQL Server】数据库开发指南(二)MSSQL数据库开发对

    2024年02月09日
    浏览(74)
  • MySQL数据库概念、管理以及SQL语句的基本命令操作

    数据(data) 描述事物的符号记录 包括数字,文字、图形、图像、声音、档案记录等 以“记录”形式按统一格式进行存储(记录可以看成一条记录) 表 将不同的记录组织在一起 用来存储具体数据 记录:行 字段(属性):列 以行+列的形式就组成了表(数据存储在表中) 数

    2024年02月08日
    浏览(70)
  • 探索SQL深入理解数据库操作的关键概念与技巧【文末送书】

    SQL(Structured Query Language,结构化查询语言)是一种用于管理关系型数据库的标准化语言。无论是在开发应用程序、进行数据分析还是进行数据库管理,掌握SQL都是至关重要的。本文将从入门级别开始,逐步引导您了解SQL语言的基础知识,直到掌握高级技巧。 创建数据库 首先

    2024年04月22日
    浏览(70)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包