【系统架构设计师】三、数据库系统(事务并发|封锁协议|数据库安全|商业智能|SQL语句)

目录

一、事务并发

1.1 事务概述

1.2 并发控制

1.3 封锁

1.3.1 X 封锁和 S 封锁

1.3.2 三级封锁协议

二、数据库安全

2.1 备份(转储)与恢复

2.2 备份分类

2.3 数据库故障

三、商业智能

3.1 数据仓库

3.2 数据仓库的结构-OLAP

3.3 数据挖掘

3.4 分布式数据库

四、SQL语句

4.1 创建表(CREATE table)

4.2 修改表(ALTER table)

4.3 删除表(DROP table)

4.4 查询(select)

4.5 分组查询(group by)****

4.6 模糊查询(like)

4.7 去除重复记录查询(distinct)

4.8 排序查询(order by)

4.9 表-插入数据(insert into)

4.10 表-删除数据(delete/truncate)

4.11 表-修改数据(updata)

4.12 聚合函数

计算和(sum)

计算最大值(max)

计算最小值(min)

计算平均值(avg)

计算个数(count)

五、真题练习


一、事务并发

1.1 事务概述

        DBMS 运行的基本工作单位是事务,事务是用户定义的一个数据库操作序列,这些操作序列要么全做,要么全都不做,是一个不可分割的工作单位。事务具有的四个特性(ACID):

  • (操作)原子性(Atomicity):事务是数据库的逻辑工作单位,事务的所有操作在数据库中要么 全做,要么全都不做。

  • (数据)一致性(Consistency):事务的执行使数据库从一个一致性状态变成另一个一致性状态。

  • (执行)隔离性(Isolation):一个事务的执行不能被其他事务干扰。

  • (改变)持久性(Durability):指一个事务一旦提交,它对数据库的改变必须是永久的,即便系统出现故障时也是如此。

1.2 并发控制

        事务是并发控制的前提条件,并发控制就是控制不同的事务并发执行,提高系统效率,但是并发控制中存在下面三个问题:

  • 丢失更新:事务1对数据A进行了修改并写回,事务2也对A进行了修改并写回此时事务2写回的数据会覆盖事务1写回的数据,就丢失了事务1对A的更新。即对数据A的更新会被覆盖。

  • 不可重复读:事务2读A,而后事务1对数据A进行了修改并写回,此时若事务2再读A,发现数据不对。即一个事务重复读A两次,会发现数据A有误。

  • 读脏数据:事务1对数据A进行了修改后,事务2读数据A,而后事务1回滚,数据A恢复了原来的值,那么事务2对数据A做的事是无效的,读到了脏数据。

1.3 封锁

1.3.1 X 封锁和 S 封锁

        并发控制的主要技术是封锁,主要有两种类型的封锁,分别是 X 封锁 和 S 封锁。

  • 排他型封锁(X 封锁):如果事务 T 对数据 A(可以是数据项、记录、数据集以至整个数据库)实现了 X 封锁,那么只允许事务 T 读取和修改数据 A,其他事务要等事务 T 解除 X 封锁以后,才能对数据 A 实现任何类型的封锁。可见 X 封锁只允许一个事务独锁某个数据,具有排他性。

  • 共享型封锁(S 封锁):如果事务 T 对数据 A 实现了 S 封锁,那么允许事务 T 读取数据A,但不能修改数据 A,在所有 S 封锁解除之前决不允许任何事务对数据 A 实现 X 封锁。

1.3.2 三级封锁协议

  • 一级封锁协议:事务在修改数据R之前必须先对其加X锁,直到事务结束才释放。可解决丢失更新问题

  • 二级封锁协议:一级封锁协议的基础上加上事务T在读数据R之前必须先对其加S锁读完后即可释放S锁可解决丢失更新、读脏数据问题

  • 三级封锁协议:一级封锁协议加上事务T在读取数据R之前先对其加S锁,直到事务结束才释放可解决丢失更新、读脏数据、数据重复读问题

二、数据库安全

2.1 备份(转储)与恢复

  • 备份是指通过数据转储和监理日志文件的方法监理冗余数据,DBA定期地将整个数据库复制到磁带或另一个磁盘上保存起来的过程。这些备用的数据文本称为后备副本。

  • 恢复是指把数据库从错误状态恢复到某一个已知的正确状态的功能。当数据库遭到破坏后,就可以利用后备副本把数据库恢复,这时数据库只能恢复到备份时的状态,从那以后的所有更新事务必须重新运行才能恢复到故障时的状态。

2.2 备份分类

  • 静态转储:即冷备份,指在转储期间不允许对数据库进行任何存取、修改操作。
    • 优点是非常快速的备份方法、容易归档(直接物理复制操作)

    • 缺点是只能提供到某一时间点上的恢复,不能做其他工作,不能按表或按用户恢复。

  • 动态转储:即热备份,在转储期间允许对数据库进行存取、修改操作,因此转储和用户事务可并发执行。
    • 优点是可在表空间或数据库文件级备份,数据库扔可使用,可达到秒级恢复;

    • 缺点是不能出错,否则后果严重,若热备份不成功,所得结果几乎全部无效。

  • 完全备份(海量备份):备份所有数据。

  • 差量备份:仅备份上一次完全备份之后变化的数据。

  • 增量备份:备份上一次备份之后变化的数据。

2.3 数据库故障

        数据库的 4 类故障:事务故障、系统故障、介质故障、计算机病毒。

        事务故障的恢复有两个操作:撤销事务(UNDO)和 重做事务(REDO)。

        介质故障的恢复由数据库管理员装入数据库的副本和日记文件副本,再由系统执行撤销和重做操作。

        日志文件:在事务处理过程中,DBMS把事务开始、事务结束以及对数据库的插入、删除和修改的每一次操作写入日志文件。一旦发生故障,DBMS的恢复子系统利用日志文件撤销事务对数据库的改变,回退到事务的初始状态。

三、商业智能

        商业智能(Business Intelligence,BI)是企业对商业数据的搜集、管理和分析的系统过程,目的是使企业的各级决策者获得知识或洞察力,帮助他们作出对企业更有利的决策。一般认为数据仓库、联机分析处理(OLAP)和数据挖掘是商业智能的三大组成部分。

3.1 数据仓库

        数据仓库是一个面向主题的、集成的、非易失的、且随时间变化的数据集合,用于支持管理决策。数据仓库的关键特征是:面向主题、集成的、非易失的、时变的。

  • 面向主题:按照一定的主题域进行组织的。

  • 集成的:数据仓库中的数据是在对原有分散的数据库数据抽取、清理的基础上经过系统加工、汇总和整理得到的,必须消除源数据中的不一致性,以保证数据仓库内的信息是关于整个企业的一致的全局信息

  • 相对稳定的:数据仓库的数据主要供企业决策分析之用,所涉及的数据操作主要是数据查询,旦某个数据进入数据仓库以后,一般情况下将被长期保留,也就是数据仓库中一般有大量的查询操作,但修改和删除操作很少,通常只需要定期的加载、刷新。

  • 反映历史变化:数据仓库中的数据通常包含历史信息,系统记录了企业从过去某一时点(如开始应用数据仓库的时点)到目前的各个阶段的信息,通过这些信息,可以对企业的发展历程和未来趋势做出定量分析和预测。

传统数据库与数据仓库的比较
传统数据库与数据仓库的比较

3.2 数据仓库的结构-OLAP

数据仓库的结构通常包含四个层次,如上图所示:

  • 1.数据源:是数据仓库系统的基础,是整个系统的数据源泉。

  • 2.数据的存储与管理:是整个数据仓库系统的核心。

  • 3.0LAP(联机分析处理)服务器:对分析需要的数据进行有效集成,按多维模型组织,以便进行多角度、多层次的分析,并发现趋势

  • 4.前端工具:主要包括各种报表工具、查询工具、数据分析工具、数据挖掘工具以及各种基于数据仓库或数据集市的应用开发工具。

OLTP 即联机事务处理,就是关系数据库的基础;OLAP即联机分析处理,是数据仓库的核心部分。

OLTP 与 OLAP 的区别
OLTP 与 OLAP 的区别

3.3 数据挖掘

        数据挖掘是在没有明确假设的前提下去挖掘信息、发现知识。数据挖掘所得到的信息应具有先知、有效和实用三个特征。先前未知的信息是指该信息是预先未曾预料到的,即数据挖掘是要发现那些不能靠直觉发现的信息或知识,甚至是违背直觉的信息或知识,挖掘出的信息越是出乎意料,就可能越有价值。

3.4 分布式数据库

        局部数据库位于不同的物理位置,使用一个全局DBMS将所有局部数据库联网管理,这就是分布式数据库。

  • 分片模式
    • 水平分片:将表中水平的记录分别存放在不同的地方。

    • 垂直分片:将表中垂直的列值分别存放在不同的地方。

  • 分布透明性
    • 分片透明性:用户或应用程序不需要知道逻辑上访问的表具体是如何分块存储的

    • 位置透明性:应用程序不关心数据存储物理位置的改变

    • 逻辑透明性:用户或应用程序无需知道局部使用的是哪种数据模型

    • 复制透明性:用户或应用程序不关心复制的数据从何而来

四、SQL语句

4.1 创建表(CREATE table)

//学生表创建
CREATE table student(
Sno CHAR(9) PRIMARY KEY,
Sname CHAR(20) UNIQUE,
Ssex char(2),
Sage SMALLINT,
Sdept char(20)
);
  • PRIMARY KEY,指定主键;

  • FOREIGN KEY,指定外键。

4.2 修改表(ALTER table)

//修改表名
alter table 表名 rename to 新的表名;

4.3 删除表(DROP table)

//删除表
drop table 表名;
//删除表时判断表是否存在,若存在则删除
drop table if exists 表名;

4.4 查询(select)

//查询表中所有数据
select * from 表名;//查询users表中年龄在18~25岁之间的记录
//方式1 &&
select *from users where age>=18 && age<=25;
//方式2 and
select * from users where age>=18 and age<=25;
//方式3 between..and..
select *from users where age between 18 and 25;

4.5 分组查询(group by)****

-- 查询users表中的记录,按照性别分组
select gender from users group by gender;

4.6 模糊查询(like)

  • _ 单个任意字符

  • % 0个/多个任意字符

//查询users表中姓名第二个字为帅的记录
select * from users where name like '_帅%';
//查询users表中姓名含有帅字的记录
select * from users where name like '%帅%';

4.7 去除重复记录查询(distinct)

//查询users表中所在城市不相同的记录
-- select distinct 字段 from 表名;
//去掉 name 重复的部分
select distinct name from users;

4.8 排序查询(order by)

排序order by,默认为升序,降序要加关键字DESC。

//查询users表中记录,并以年龄升序排序
select * from users order by age asc;
select * from users where age > 18 order by id;
//查询users表中记录,并以年龄降序排序
select * from users order by age desc;

4.9 表-插入数据(insert into)

有多少个字段,就要写多少个值,且是一一对应的。

insert into 表名 values(值1,值2,值3...值n);

4.10 表-删除数据(delete/truncate)

//删除表中所有数据
delete from 表名;   
//删除表中指定的数据
delete from 表名 where 字段 = 值;  
//删除表中所有数据(先删除整张表,然后创建一张一样的空表,此方法更高效)
truncate table 表名;

drop table 表名; 是连表一起删除

4.11 表-修改数据(updata)

//无限制条件的修改,会修改整张表
update 表名 set 字段 = 值;
//有限制条件的修改,只修改特定记录
update 表名 set 字段 = 值 where 条件(字段 = 值);

4.12 聚合函数

计算和(sum)

  //将求和后输出的字段以sumvalue展示 //默认以sum(字段)展示 select sum(字段) as sumvalue from 表名;select sum(id) as ID,count(id) ID_count from users;

计算最大值(max)

  select max(字段) as maxvalue from 表名;select max(age) as maxvalue from 表名;

计算最小值(min)

  select min(字段) as minvalue from 表名;select min(age) as minvalue from 表名;

计算平均值(avg)

  select avg(字段) as avgvalue from 表名;

计算个数(count)

  select count(字段) as totalcount from 表名;

五、真题练习

  • 5.1

A.封锁        B.死锁
C.循环        D.并发处理
  • 5.2 商业智能将企业中现有的数据转化为知识,帮助企业做出明智的业务经营决策,包括数据预处理、建立数据模型、数据分析及数据展现 4个阶段;其主要应用的3个关键技术是()。

    • A.数据仓库/OLAP/数据挖掘

    • B.ETL/OLAP/数据展现

    • C.数据仓库/OLTP/OLAP

    • D.数据集市/数据挖掘/数据质量标准

  • 5.3 数据仓库不包括

    • A.数据源

    • B.OLAP 服务器

    • C.OLTP 服务器

    • D.报表工具

  • 5.4 某公司网上销售管理系统的数据库部分关系模式如下所示。其中,客户号唯一标识一位客户,产品号唯一标识一件产品,订单号唯一标识一份订单。一份订单必须目仅对应一位客户,一份订单可由一到多条订单明细组成,一位客户可以有多份订单。

    • 客户(客户号,姓名,性别,地址,邮编)

    • 产品(产品号,名称,库存,单价)

    • 订单(订单号,时间,金额,客户号)

    • 订单明细(订单号,产品号,数量)

    • 订单关系模式的主键为(1);

    • 订单明细关系模式的主键为(2);

    • 其中订单的外键为(3)。

1.
A.订单号             B.客户号
C.(订单号,客户号)     D.(订单号,时间)
2.
A.订单号             B.客户号
C.(订单号,客户号)     D.(订单号,时间)
3.
A.客户号,订单明细的外键为订单号
B.客户号,订单明细的外键为订单号和产品号
C.订单号,订单明细的外键为产品号
D.订单号,订单明细的外键为订单号和产品号

答案

  • 5.1 B

  • 5.2 A

  • 5.3 C

  • 5.4 A、C、B

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/356957.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【猫狗分类】Pytorch VGG16 实现猫狗分类1-数据清洗+制作标签文件

Pytorch 猫狗分类 用Pytorch框架&#xff0c;实现分类问题&#xff0c;好像是学习了一些基础知识后的一个小项目阶段&#xff0c;通过这个分类问题&#xff0c;可以知道整个pytorch的工作流程是什么&#xff0c;会了一个分类&#xff0c;那就可以解决其他的分类问题&#xff0…

intouch的报警怎么发到企业微信机器人

厂务报警通知系列博客目录 intouch的报警怎么发到微信上 intouch的报警怎么发到邮件上 intouch的报警怎么发到短信上 intouch的报警怎么发到企业微信机器人 intouch的报警怎么发到飞书机器人 intouch的报警怎么用语音通知到手机用户 创建企业微信群机器人 打开企业微信客…

java基于ssm+jsp 母婴用品网站

1管理员功能模块 管理员登录&#xff0c;管理员通过输入用户名、密码等信息进行系统登录&#xff0c;如图1所示。 图1管理员登录界面图 管理员登录进入母婴用品网站可以查看主页、个人中心、用户管理、商品分类管理、商品信息管理、留言板管理、成长交流、系统管理、订单管理、…

6月27日云技术研讨会 | 中央集中架构新车型功能和网络测试解决方案

会议摘要 “软件定义汽车”新时代下&#xff0c;整车电气电气架构向中央-区域集中式发展已成为行业共识&#xff0c;车型架构的变革带来更复杂的整车功能定义、更多的新技术的应用&#xff08;如SOA服务化、TSN等&#xff09;和更短的车型研发周期&#xff0c;对整车和新产品研…

视频与音频的交响:探索达摩院VideoLLaMA 2的技术创新

一、简介 文章&#xff1a;https://arxiv.org/abs/2406.07476 代码&#xff1a;https://github.com/DAMO-NLP-SG/VideoLLaMA2 VideoLLaMA 2是由阿里巴巴集团的DAMO Academy团队开发的视频大型语言模型&#xff08;Video-LLM&#xff09;&#xff0c;旨在通过增强空间-时间建模…

Axios进阶

目录 axios实例 axios请求配置 拦截器 请求拦截器 响应拦截器 取消请求 axios不仅仅是简单的用基础请求用法的形式向服务器请求数据&#xff0c;一旦请求的端口与次数变多之后&#xff0c;简单的请求用法会有些许麻烦。所以&#xff0c;axios允许我们进行创建axios实例、ax…

Python基础入门

目录 1. 什么是Python&#xff1f; 2. 安装Python 3. Python基础语法 4. 数据结构 5. 文件操作 6. Python标准库 总结 1. 什么是Python&#xff1f; Python是一种高级编程语言&#xff0c;由Guido van Rossum于1991年发布。它以其简单易读的语法和强大的功能而闻名&…

DataWhale - 吃瓜教程学习笔记(二)

学习视频&#xff1a;第3章-一元线性回归_哔哩哔哩_bilibili 西瓜书对应章节&#xff1a; 3.1 - 3.2 一元线性回归 - 最小二乘法 - 极大似然估计 - 梯度 多元函数的一阶导数 - 海塞矩阵 多元函数的二阶导数 - 机器学习三要素

LLC开关电源开发:第四节,LLC软件设计报告

LLC源代码链接 数控全桥LLC开发板软件设计报告  1. LLC硬件及软件框架2. LLC软件设计2.1 工程文件说明2.2 LLC中断设计2.2.1 20us中断2.2.2 5ms中断 2.3 LLC状态机设计2.3.1 初始化状态2.3.2 空闲状态2.3.3 软启动状态2.3.4 正常运行状态2.3.5 故障状态 2.4 环路设计2.4.1 环路…

EasyRecovery数据恢复软件2024免费版下载

EasyRecovery数据恢复软件&#xff0c;是我在电脑使用过程中遇到的神器&#xff01;它不仅功能强大&#xff0c;操作简便&#xff0c;还帮我找回了丢失的重要文件。今天&#xff0c;我就来给大家分享一下我的使用体验和心得。 让我来介绍一下EasyRecovery的功能。这款软件可以恢…

【字符串 状态机动态规划】1320. 二指输入的的最小距离

本文涉及知识点 动态规划汇总 字符串 状态机动态规划 LeetCode1320. 二指输入的的最小距离 二指输入法定制键盘在 X-Y 平面上的布局如上图所示&#xff0c;其中每个大写英文字母都位于某个坐标处。 例如字母 A 位于坐标 (0,0)&#xff0c;字母 B 位于坐标 (0,1)&#xff0…

org.springframework.boot:spring-boot-starter-parent:pom:2.3.4.RELEAS

前言 git上拉了一个项目构建过程中无论是clean还是install都报错 注&#xff1a;很看不惯某博主一点简单的经验分享都要开VIP才能查看的作风 org.springframework.boot:spring-boot-starter-parent:pom:2.3.4.RELEASE failed to transfer from https://maven.aliyun.com/rep…

3D视觉引导机器人提升生产线的自动化水平和智能化程度

随着智能化技术的不断发展&#xff0c;汽车制造企业正积极寻求提升智能化水平的途径。富唯智能的3D视觉引导机器人抓取技术为汽车制造企业提供了一种高效、智能的自动化解决方案。 项目目标 某汽车制造企业希望通过引入智能化技术提升生产线的自动化水平和智能化程度。他们希望…

湖南(市场调研)源点咨询 新产品上市前市场机会调研与研究分析

湖南源点调研认为&#xff1a;无论是创业公司&#xff0c;还是在公司内部探索新的项目或者新的产品线等&#xff0c;首先都要做“市场机会分析与调研“&#xff0c;要真正思考并解答以下疑问&#xff1a; 我们的目标客户群体是谁&#xff0c;他们如何决策&#xff1f; 我们所…

AI大眼萌探索 AI 新世界:Ollama 使用指南【1】

在人工智能的浪潮中&#xff0c;Ollama 的出现无疑为 Windows 用户带来了一场革命。这款工具平台以其开创性的功能&#xff0c;简化了 AI 模型的开发与应用&#xff0c;让每一位爱好者都能轻松驾驭 AI 的强大力量。大家好&#xff0c;我是AI大眼萌&#xff0c;今天我们将带大家…

CentOS 7.9检测硬盘坏区、实物定位(三)

系列文章目录 CentOS 7.9上创建JBOD&#xff08;一&#xff09; CentOS 7.9上创建的JBOD阵列恢复&#xff08;二&#xff09; 文章目录 系列文章目录前言一、在系统中找到硬盘对应的盘符二、使用命令定位实物1.badblocks检测坏块2.对2T以上的硬盘检测&#xff08;对本篇非必要…

SQLite数据库(数据库和链表双向转换)

文章目录 SQLite数据库一、SQLite简介1、SQLite和MySQL2、基于嵌入式的数据库 二、SQLite数据库安装三、SQLite的常用命令四、SQLite的编程操作1、SQLite数据库相关API&#xff08;1&#xff09;头文件&#xff08;2&#xff09;sqlite3_open()&#xff08;3&#xff09;sqlite…

【笔记】【矩阵的二分】668. 乘法表中第k小的数

力扣链接&#xff1a;题目 参考地址&#xff1a;参考 思路&#xff1a;二分查找 把矩阵想象成一维的已排好序的数组&#xff0c;用二分法找第k小的数字。 假设m行n列&#xff0c;则对应一维下标范围是从1到mn&#xff0c;初始&#xff1a; l1; rmn; mid(lr)/2 设mid在第i行&a…

设计模式——设计模式原则

设计模式 设计模式示例代码库地址&#xff1a; https://gitee.com/Jasonpupil/designPatterns 设计模式原则 单一职责原则&#xff08;SPS&#xff09;&#xff1a; 又称单一功能原则&#xff0c;面向对象五个基本原则&#xff08;SOLID&#xff09;之一 原则定义&#xf…

设计模式1-简介

设计模式简介 专栏的目的什么是设计模式设计模式要学什么软件开发原则主流设计模式 学习建议经典面试题 资源 专栏的目的 1.理解松耦合的设计思想 2.掌握面向对象设计原则 3.掌握重构技法改善设计 4.掌握GOF核心设计模式 什么是设计模式 每一个模式描述了一个在我们周围不…