软件设计师教程(第三版)(修订版)七章笔记

2024-01-06 20:08

本文主要是介绍软件设计师教程(第三版)(修订版)七章笔记,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

数据库系统 《== 广义包括数据库(DB)、
                        硬件、
                        软件(操作系统、数据库管理系统DBMS、应用软件)、
                        人员(系统分析员和数据库设计人员、应用程序员、最终用户、数据库管理员)
DBMS功能 《== 数据定义DDL、数据操纵DML(宿主型(嵌入C、COBOL)、自含型(用户单独使用))
DBMS特征 《== 数据结构化且统一管理、有较高的数据独立性、数据控制功能(安全性保护、数据完整性、并发控制、故障恢复)
DBMS分类 《== 关系数据库系统RDBS、面向对象数据库系统OODBS、对象关系数据库系统ORDBS
数据库体系结构 《== 集中式、分布式(物理上分布、逻辑上分布)、C/S、并行结构(共享内存式多处理器、无共享式)
数据库服务器 《== 事务服务器(查询)、数据服务器
数据库系统三级模式(试图层、逻辑层、物理层对数据抽象,外模式(用户模式)、内模式(存储模式)、概念模式(模式)描述数据特性)
          和两级映像(模式/内模式映像-物理独立性,外模式/模式映像-逻辑独立性)
E-R模型 -- 实体
           联系: 两个不同实体联系(1:1、1:n)、两个以上不同实体联系(1:1:1、1:1:n、1:m:n、r:m:n)、同一实体内的二元联系(1:1、1:n、m:n)
           属性: 简单/复合属性、单值/多值属性、NULL属性、派生属性
           方法     (p341 E-R例子)
扩充E-R模型 -- 弱实体、特殊化(全特殊化、部分特殊化、不相交特殊化、重叠特殊化)  (p343演示)
层次模型 -- 树型结构表示(不能直接多对多联系,需要2种方法实现--冗余结点法(两个结点多对多转化为两个一对多,浪费空间、数据不一致)、虚拟结点分析法(冗余结点转化为虚拟结点,结点指针可能会被修改))
网状模型(DBTG模型)(是层次模型的一个特例,不能表示多对多联系,需要引入联结记录来表示,优点直观描述世界,性能良好,存取效率高,缺点结构复杂)
关系模型 -- 用表格表达实体集和实体关系之间的联系
面向对象模型 -- 对象和对象标识OID、(状态和行为)封装、对象的属性、类和类层次、继承
关系代数  笛卡尔积 p350
关系相关名词:目或度Degree、候选码Candidate Key、主码、主属性/非码属性、外码、全码
关系三种类型 《== 基本关系(基本表)、查询表、视图表(虚表)
关系的完整性 《== 实体完整性(主属性不能空)、参照完整性(比如外码)、用户定义完整性(如取值限制)
传统集合运算(关系水平方向进行) -- 并Union、交Intersection、差Difference、广义笛卡尔积Extended Cartesian Product
专门的关系运算(水平/垂直方向进行) -- 选择Selection、投影Projection、连接join(zita连接、等值连接、自然连接)、除法(Division)  p355 p357 p358 p359 p360
                                     广义投影Generalized Projection(投影中可以使用关系代数)、外连接Outer Join(左外连接、右外连接、全外连接)  p365
SQL语言 《== 数据查询(SELECT)、数据操纵(INSERT、UPDATE、DELETE)、数据定义(CREATE、DROP、ALTER)、数据控制(GRANT、REVORK)
SQL语言对应模式:视图-外模式、基本表-模式、存储文件-内模式
sql语句例子 表/索引/视图定义、查询、更新、访问控制 p368 p370 p371-p383
SQL规范化 <== 1NF(所有域都是原子数据)、
              2NF(非主属性完全依赖于码,即取消部分函数依赖)、
              3NF(取消非主属性对码的传递函数依赖)
分解、无损链接、保持函数依赖性
事务定义 《== Begin Transaction、Commit、Roll Back
并发操作不一致 《== 丢失修改、不可重复读、读脏数据
并发控制技术 《== 封锁(排它锁(X锁/写锁)、共享锁(S锁/读锁))、三级封锁协议

这篇关于软件设计师教程(第三版)(修订版)七章笔记的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/577463

相关文章

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

python连接本地SQL server详细图文教程

《python连接本地SQLserver详细图文教程》在数据分析领域,经常需要从数据库中获取数据进行分析和处理,下面:本文主要介绍python连接本地SQLserver的相关资料,文中通过代码... 目录一.设置本地账号1.新建用户2.开启双重验证3,开启TCP/IP本地服务二js.python连接实例1.

Python 安装和配置flask, flask_cors的图文教程

《Python安装和配置flask,flask_cors的图文教程》:本文主要介绍Python安装和配置flask,flask_cors的图文教程,本文通过图文并茂的形式给大家介绍的非常详细,... 目录一.python安装:二,配置环境变量,三:检查Python安装和环境变量,四:安装flask和flas

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

Linux卸载自带jdk并安装新jdk版本的图文教程

《Linux卸载自带jdk并安装新jdk版本的图文教程》在Linux系统中,有时需要卸载预装的OpenJDK并安装特定版本的JDK,例如JDK1.8,所以本文给大家详细介绍了Linux卸载自带jdk并... 目录Ⅰ、卸载自带jdkⅡ、安装新版jdkⅠ、卸载自带jdk1、输入命令查看旧jdkrpm -qa

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

springboot简单集成Security配置的教程

《springboot简单集成Security配置的教程》:本文主要介绍springboot简单集成Security配置的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录集成Security安全框架引入依赖编写配置类WebSecurityConfig(自定义资源权限规则