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

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

注:本文的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 employe

结果为:

解释

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 语句给出表达式

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 模式定义。为每个属性选择一个适当的域,为每个关系模式选择一个适当的主键。为每个关系模式选择适当的域和主键。包括任何可能合适的外键约束。适当的外键约束(不单单看create本身对不对,前后顺序也要注意。有外码的要保证外表已经被创建)

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 company(
  company_name company_names,
  city city_names,
  primary key(company_name)
)
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 manages(
  ID char(4),
  manager_id char(4)
  foreign key(id) references employee(id)
)

3.21

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

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 avg(ci)
from(
    select member.memb_no,count(isbn)
    from borrowed,member
    where borrowed.memb_no(+)=member.memb_no
    group by member.memb_no) as tab1(memb_no,ci)
2.

总结

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

相关文章
|
3天前
|
SQL 存储 JavaScript
开发语言漫谈-SQL
SQL是另一个门类的开发语言
|
4天前
|
缓存 算法 关系型数据库
SQL DB - 关系型数据库是如何工作的
• 绿:O(1)或者叫常数阶复杂度,保持为常数(要不人家就不会叫常数阶复杂度了)。 • 红:O(log(n))对数阶复杂度,即使在十亿级数据量时也很低。 • 粉:最糟糕的复杂度是 O(n^2),平方阶复杂度,运算数快速膨胀。 • 黑和蓝:另外两种复杂度(的运算数也是)快速增长。 如果要处理2000条元素: • O(1) 算法会消耗 1 次运算 • O(log(n)) 算法会消耗 7 次运算 • O(n) 算法会消耗 2000 次运算
|
5天前
|
SQL 存储 大数据
济南sql数据库工程师
济南SQL数据库工程师是负责管理和维护SQL数据库的专业人员。以下是关于济南SQL数据库工程师的一些详细介绍: 一、岗位职责 1. 负责数据库日常巡检,及时反馈运行状况,并跟踪解决问题,确
45 21
|
5天前
|
SQL 供应链 关系型数据库
数据库sql超市
当涉及到使用SQL来管理超市数据库时,通常需要考虑多个方面,包括商品管理、订单处理、销售分析、库存管理等。以下是一个简单的超市数据库SQL示例,以及一些常见的查询操作。 **1. 数据库表设计*
46 17
|
5天前
|
SQL 监控 数据库
sql anywhere 数据库优化
\ Anywhere\对于任何数据库系统,优化都是持续的过程,旨在提高查询性能、减少资源消耗并确保数据的完整性和安全性。以下是一些建议,帮助您优化 SQL Anywhere 数据库: 1. **
41 5
|
5天前
|
SQL 监控 安全
sql数据库清除工具
在SQL数据库管理中,清理和优化数据库是一个重要的环节,特别是当数据库日志文件过大时。虽然没有特定的“SQL数据库清除工具”可以一键解决所有问题,但你可以使用多种方法和工具来清理SQL Server数
27 6
|
5天前
|
SQL 关系型数据库 MySQL
sql数据库命令
SQL(Structured Query Language,结构化查询语言)是用于管理关系数据库的标准编程语言。以下是一些常用的 SQL 数据库命令: 1. **创建数据库**: ``
26 7
|
19天前
|
SQL 关系型数据库 MySQL
MySQL技能完整学习列表3、SQL语言基础——1、SQL(Structured Query Language)简介——2、基本SQL语句:SELECT、INSERT、UPDATE、DELETE
MySQL技能完整学习列表3、SQL语言基础——1、SQL(Structured Query Language)简介——2、基本SQL语句:SELECT、INSERT、UPDATE、DELETE
58 0
|
8月前
|
SQL 关系型数据库 数据库
关系数据库SQL语言简介
一、关系数据库SQL语言简介 SQL(Structured Query Language)是关系型数据库管理系统(RDBMS)中最常用的语言。它是一种标准化的语言,用于存储、操作和查询数据。SQL语言具有以下特点: 1. 数据操作语言(DML):用于对数据库中的数据进行增、删、改等操作,包括INSERT、UPDATE、DELETE等命令。 2. 数据定义语言(DDL):用于定义数据库的结构,包括表、字段、索引、视图等,包括CREATE、ALTER、DROP等命令。 3. 数据查询语言(DQL):用于查询数据库中的数据,包括SELECT、FROM、WHERE等命令。 4. 数据控制语言(DCL)
198 0
|
8月前
|
SQL 数据管理 数据库
关系数据库SQL语言简介
关系数据库SQL语言简介 一、SQL语言概述 SQL(Structured Query Language)是一种用于管理和操作关系数据库的语言。它是数据库管理系统(DBMS)的核心组成部分,用于定义、操作和查询数据库中的数据。SQL语言是一种标准化的语言,由美国国家标准局(ANSI)和国际标准化组织(ISO)制定和维护。 SQL语言具有简洁、易学、易用的特点,被广泛应用于各个领域的数据管理和应用开发中。通过SQL语言,用户可以使用简单的语句来完成复杂的数据查询、更新、删除等操作,实现对数据库的全面管理和控制。 SQL语言主要包括以下几个方面的内容: 1. 数据定义语言(DDL):用于
66 0