《高并发Oracle数据库系统的架构与设计》epub下载在线阅读全文,求百度网盘云资源

《高并发Oracle数据库系统的架构与设计》epub下载在线阅读全文,求百度网盘云资源,第1张

《高并发Oracle数据系统的架构与设计》(侯松)电子书网盘下载免费在线阅读

链接:> 提取码:MEDB  

书名 :高并发Oracle数据库系统的架构与设计

豆瓣评分:

作者: 侯松

出版社: 机械工业出版社

出版年: 2014-11-1

页数: 388

内容简介:

这是国内第一本深度讲解如何架构与设计高并发Oracle数据库系统的著作,也是国内第一本系统讲解内存数据库TimesTen的专著。作者是拥有10余年Oracle从业经验的资深数据库架构师,本书的内容也得到了业界以盖国强为代表的数位数据库专家的一致认可。本书秉承大道至简的思想,技术与艺术并重,从技术、方法论、原理和思想等角度讲解了如何架构与设计高并发Oracle数据库系统。

全书主要内容从三个维度展开:首先是内部扩展的维度,深入探讨了高效B树索引、高效表设计、查询优化器等数据库架构设计与优化的核心技术,以及高并发Oracle数据库系统架构与设计的方法论和常见的高并发案例;其次是纵向扩展的维度,国内首次详细讲解了内存数据库TimesTen的基本使用、高可用架构设计、缓存应用、监控方法、数据备份与恢复、数据迁移以及高并发场景;最后是横向扩展的维度,详细讲解了

作者简介 :

侯松(网名:麻袋爸爸)

资深数据库架构师、PMP、北美寿险管理师,现就职于中国平安保险集团,拥有10余年数据库开发、管理和运维经验。精通Oracle数据库相关技术,掌握ITIL运维体系,擅长金融行业(银行、保险、投资)的项目管理和数据库系统的架构设计,有世界500强IT团队管理与大型项目管理的经验。活跃于ITPUB等技术社区,2013年中国数据库大会演讲嘉宾。个人网站:>

MySQL数据库的体系架构如下图所示:

从上图中可以看出,MySQL主要分为以下几个组件:

连接池组件

管理服务和工具组件

SQL接口组件

分析器组件

优化器组件

缓冲组件

插件式存储引擎

物理文件

如果两种数据库系统之间的数据定义模型不同,如分别为关系模型和层次模型,那么需要重新定义实体属性和联系,以防止属性或联系信息的丢失。

----总之,在进行数据转换后,一方面源数据库模式中所有需要共享的信息都转换到目的数据库中,另一方面这种转换又不能包含冗余的关联信息。

----数据库转换工具可以实现不同数据库系统之间的数据模型转换,需要进一步研究的问题是:如果数据库转换同时进行数据定义模式转换和数据转换,就可能引起同一数据集合在异构数据库系统中存在多个副本,因此需要引入新的访问控制机制。在保证各个参与数据库自治,维护其完整性、安全性的基础上,对于异构数据库系统提供全局的访问控制、并发机制和安全控制。

----如果数据库转换只进行数据定义转换,不产生数据的副本,那么在新的目的数据库定义模型的框架下访问数据,实现上仍是对源数据库系统中数据的访问。这时利用新的数据库系统中的数据处理语言实现的事务,不能直接访问源数据库,必须进行事务级的翻译才可以执行。

开头

----------------------------------

<%@LANGUAGE="VBSCRIPT"%>

<%

option explicit

dim startime,endtime

dim conn,connstr,db

startime=timer()

db="data/classmdb" '数据库相对路径

Set conn = ServerCreateObject("ADODBConnection") '新建connnection对象

connstr="Provider=MicrosoftJetOLEDB40;Data Source=" & ServerMapPath(db)

'如果你的服务器采用较老版本Access驱动,请用下面连接方法

'connstr="driver={Microsoft Access Driver (mdb)};dbq=" & ServerMapPath(db)

connOpen connstr '打开conn连接

dim rs,sql

set rs=servercreateobject("adodbrecordset")

sql="select from [user] where userid=10" '打开user表的字段userid=10的那项

rsopen sql,1,1 '一般浏览

responsewrite rs("username") 显示其中的一个字段的值

rs close

rsopen sql,1,3 '一般修改插入语句

rsaddnew '表示是插入

rs("username")="Fly"

rsupdate '表示执行上述修改或插入

rs close

rsopen sql,3,2 '一般删除语句

rsdelect

rs close

connclose '关闭连接

set conn=nothing

其实就是sql语言的功效

SQL数据库完全手册

日期:2001-3-24 0:47:00

出处:电脑报

作者:未知

SQL是Structured Quevy Language(结构化查询语言)的缩写。SQL是专为数据库而建立的 *** 作命令集,是一种功能齐全的数据库语言。在使用它时,只需要发出“做什么”的命令,“怎么做”是不用使用者考虑的。SQL功能强大、简单易学、使用方便,已经成为了数据库 *** 作的基础,并且现在几乎所有的数据库均支持SQL。

##1 二、SQL数据库数据体系结构

SQL数据库的数据体系结构基本上是三级结构,但使用术语与传统关系模型术语不同。在SQL中,关系模式(模式)称为“基本表”(base table);存储模式(内模式)称为“存储文件”(stored file);子模式(外模式)称为“视图”(view);元组称为“行”(row);属性称为“列”(column)。名称对称如^00100009a^:

##1 三、SQL语言的组成

在正式学习SQL语言之前,首先让我们对SQL语言有一个基本认识,介绍一下SQL语言的组成:

1一个SQL数据库是表(Table)的集合,它由一个或多个SQL模式定义。

2一个SQL表由行集构成,一行是列的序列(集合),每列与行对应一个数据项。

3一个表或者是一个基本表或者是一个视图。基本表是实际存储在数据库的表,而视图是由若干基本表或其他视图构成的表的定义。

4一个基本表可以跨一个或多个存储文件,一个存储文件也可存放一个或多个基本表。每个存储文件与外部存储上一个物理文件对应。

5用户可以用SQL语句对视图和基本表进行查询等 *** 作。在用户角度来看,视图和基本表是一样的,没有区别,都是关系(表格)。

6SQL用户可以是应用程序,也可以是终端用户。SQL语句可嵌入在宿主语言的程序中使用,宿主语言有FORTRAN,COBOL,PASCAL,PL/I,C和Ada语言等。SQL用户也能作为独立的用户接口,供交互环境下的终端用户使用。

##1 四、对数据库进行 *** 作

SQL包括了所有对数据库的 *** 作,主要是由4个部分组成:

1数据定义:这一部分又称为“SQL DDL”,定义数据库的逻辑结构,包括定义数据库、基本表、视图和索引4部分。

2数据 *** 纵:这一部分又称为“SQL DML”,其中包括数据查询和数据更新两大类 *** 作,其中数据更新又包括插入、删除和更新三种 *** 作。

3数据控制:对用户访问数据的控制有基本表和视图的授权、完整性规则的描述,事务控制语句等。

4嵌入式SQL语言的使用规定:规定SQL语句在宿主语言的程序中使用的规则。

下面我们将分别介绍:

##2 (一)数据定义

SQL数据定义功能包括定义数据库、基本表、索引和视图。

首先,让我们了解一下SQL所提供的基本数据类型:(如^00100009b^)

1数据库的建立与删除

(1)建立数据库:数据库是一个包括了多个基本表的数据集,其语句格式为:

CREATE DATABASE <数据库名> 〔其它参数〕

其中,<数据库名>在系统中必须是唯一的,不能重复,不然将导致数据存取失误。〔其它参数〕因具体数据库实现系统不同而异。

例:要建立项目管理数据库(xmmanage),其语句应为:

CREATE DATABASE xmmanage

(2) 数据库的删除:将数据库及其全部内容从系统中删除。

其语句格式为:DROP DATABASE <数据库名>

例:删除项目管理数据库(xmmanage),其语句应为:

DROP DATABASE xmmanage

2基本表的定义及变更

本身独立存在的表称为基本表,在SQL语言中一个关系唯一对应一个基本表。基本表的定义指建立基本关系模式,而变更则是指对数据库中已存在的基本表进行删除与修改。

(1)基本表的定义:基本表是非导出关系,其定义涉及表名、列名及数据类型等,其语句格式为:

CREATE TABLE〔<数据库名>〕<表名>

(<列名> 数据类型 〔缺省值〕 〔NOT NULL / NULL〕

〔,<列名> 数据类型 〔缺省值〕 〔NOT NULL / NULL〕〕

〔,UNIQUE (列名〔,列名〕)〕

〔,PRIMARY KEY(列名)〕

〔,FOREIGN KEY(列名〔,列名〕)REFERENCE <表名>(列名〔,列名〕)〕

〔,CHECK(条件)〕 〔其它参数〕)

其中,〈数据库名〉〕指出将新建立的表存放于该数据库中;

新建的表由两部分组成:其一为表和一组列名,其二是实际存放的数据(即可在定义表的同时,直接存放数据到表中);

列名为用户自定义的易于理解的名称,列名中不能使用空格;

数据类型为上面所介绍的几种标准数据类型;

〔NOT NULL/NULL〕指出该列是否允许存放空值,SQL语言支持空值的概念,所谓空值是“不知道”或“无意义”的值,值得注意的是数据“0”和空格都不是空值,系统一般默认允许为空值,所以当不允许为空值时,必须明确使用NOT NULL;

〔,UNIQUE〕将列按照其规定的顺序进行排列,如不指定排列顺序,则按列的定义顺序排列;

〔PRIMARY KEY〕用于指定表的主键(即关系中的主属性),实体完整性约束条件规定:主键必须是唯一的,非空的;

〔,FOREIGN KEY (列名〔,列名〕) REFERENCE<表名>(列名〔,列名〕)〕是用于指定外键参照完整性约束条件,FOREIGN KEY指定相关列为外键,其参照对象为另外一个表的指定列,即使用REFERENCE引入的外表中的列,当不指定外表列名时,系统将默认其列名与参照键的列名相同,要注意的是:使用外键时必须使用参照,另外数据的外键参照完整性约束条件规定:外键的值要么与相对应的主键相同,要么为空值(具体由实现系统不同而异)

〔,CHECK〕用于使用指定条件对存入表中的数据进行检查,以确定其合法性,提高数据的安全性。

例:要建立一个学生情况表(student)

CREATE TABLE student //创建基本表student

(st_class CHAR(8),// 定义列st_class班级,数据类型为8位定长字符串

st_no CHAR(10) NOT NULL,//定义列st_no学号,类型为10位定长字符串,非空

st_name CHAR(8) NOT NULL,//定义列st_name姓名,类型为8位定长字符串,非空

st_sex CHAR(2),//定义列st_sex性别,类型为2位定长字符串

st_age SMALLINT,//定义列st_age年龄,类型为短整型

PRIMARY KEY (st_no))//定义st_no学号为主键。

例:要建立课程设置表(subject)

CREATE TABLE subject//创建基本表subject

(su_no CHAR(4) NOT NULL,// 定义列su_no课号,类型为4位定长字符串,非空

su_subject CHAR(20) NOT NULL,// 定义列su_subject课程名,类型为20位定长字符串,非空

su_credit INTEGER,// 定义列su_credit学分,类型为长整数

su_period INTEGER,//定义列su_period学时,类型为长整数

su_preno CHAR(4),//定义列su_preno先修课号,类型为4位定长字符串

PRIMARY KEY(su_no))//定义su_no课号为主键。

例:要建立学生选课表(score)

CREATE TABLE score //创建基本表score

(st_no CHAR(10),//定义列st_no学号,类型为10位定长字符串

su_no CHAR(4),//定义列su_no课号,类型为4位定长字符串

sc_score INTEGER NULL,//定义列sc_score,类型为长整形,可以为空值

FOREIGN KEY (st_no) REFERENCE student,//从表student中引入参照外键st_no,以确保本表与表student的关联与同步

FOREIGN KEY (suno) REFERENCE subject)//从表subject中引入参照外键su_no,以确保本表与表subject的关联与同步

(2)基本表的删除:用以从数据库中删除一个基本表及其全部内容,其语句格式为:

DROP TABLE〔<数据库名>〕表名

例如:将上面建立的表都删除

DROP TABLE student,subject,score

(3)基本表的修改:在基本表建立并使用一段时间后,可能需要根据实际要求对基本表的结构进行修改,即增加新的属性或删除属性。

增加属性的语句格式为:

ALTER TABLE 〔<数据库名>〕表名 ADD

(<列名> 数据类型 〔缺省值〕 〔NOT NULL / NULL〕

〔,<列名> 数据类型〔缺省值〕〔NOT NULL / NULL〕〕

〔,UNIQUE (列名〔,列名〕)〕

〔,PRIMARY KEY(列名)〕

〔,FOREIGN KEY(列名〔,列名〕) REFERENCE <表名>(列名〔,列名〕)〕

〔,CHECK(条件)〕〔其它参数〕)

例如:在基本表student中加入列stborn出生日期,数据类型为DATE,且不能为空值

ALTER TABLE student ADD (stborn DATE NOT NULL)

删除属性的语句格式为:

ALTER TABLE 〔<数据库名>〕表名 DROP

( <列名> 数据类型 〔缺省值〕〔NOT NULL / NULL〕

〔,<列名> 数据类型 〔缺省值〕〔NOT NULL / NULL〕〕)

例如:将基本表student中的列st_age删除

ALTER TABLE student DROP (st_age)

3视图定义与删除

在SQL中,视图是外模式一级数据结构的基本单位。它是从一个或几个基本表中导出的表,是从现有基本表中抽取若干子集组成用户的“专用表”。这种构造方式必须使用SQL中的SELECT语句来实现。在定义一个视图时,只是把其定义存放在系统的数据中,而并不直接存储视图对应的数据,直到用户使用视图时才去求得对应的数据。

(1)视图的定义:定义视图可以使用CREATE VIEW语句实现,其语句格式为:

CREATE VIEW 视图名 AS SELECT语句

从一个基本表中导出视图:

例:从基本表student中导出只包括女学生情况的视图

CREATE VIEW WOMANVIEW AS //创建一个视图WOMANVIEW

SELECT st_class,st_no,st_name,st_age //选择列st_class,st_no,st_name,st_age显示

FROM student //从基本表student引入

WHERE st_sex=‘女’//引入条件为性别为“女”,注意字符变量都使用单引号引用

从多个基本表中导出视图:

例如:从基本表student和score中导出只包括女学生且分数在60分以上的视图

CREATEVIEW WOMAN_SCORE AS //定义视图WOMANSCORE

SELECT studentst_class,studentst_no,studentst_name,studentst_age,scoresc_score //有选择性显示相关列

FROM studentscore //从基本表student和score中引入

WHERE studentst_sex=‘女’AND scoresc_score>=60 AND studentst_no=scorest_no //选择条件:性别为“女” 且分数在60分以上。并使用st_no将两表联系起来。

以后如果进行这一视图的应用,则只需使用语句

SELECT FROM WOMAN_SCORE //其中“”为通配符,代表所有元素

(2)视图的删除:用于删除已不再使用的视图,其语句格式如下:

DROP VIEW 视图名

例:将上面建立的WOMAN_SCORE视图删除

DROP VIEW WOMAN_SCORE

4索引的定义与删除

索引属于物理存储概念,而不是逻辑的概念。在SQL中抛弃了索引概念,直接使用主键概念。值得一提的是,有些关系DBMS同时包括索引机制和主键机制,这里我们推荐使用主键机制,因为它对系统资源占用较低且效率较高。

(1)索引的定义:索引是建立在基本表之上的,其语句格式为:

CREATE 〔UNIQUE〕 INDEX 索引名 ON

〔<数据库名>〕表名(列名 〔ASC/DESC〕〔,列名 〔ASC/DESC〕〕)

这里,保留字UNIQUE表示基本表中的索引值不允许重复,若缺省则表示索引值在表中允许重复;DESC表示按索引键降序排列,若缺省或ASC表示升序排列。

例:对基本表student中的st_no和st_age建立索引,分别为升序与降序,且索引值不允许重复

CREATE UNIQUE INDEX STINDEX ON//创建索引STINDEX

student(st_no ASC,st_age DESC)//对student中的st_no和st_age建立索引

(2)索引的删除:

DROP INDEX 索引名

例:删除上面建立的索引STINDEX

DROP INDEX STINDEX

##2 (二)数据查询

SQL是一种查询功能很强的语言,只要是数据库存在的数据,总能通过适当的方法将它从数据库中查找出来。SQL中的查询语句只有一个:SELECT,它可与其它语句配合完成所有的查询功能。SELECT语句的完整语法,可以有6个子句。完整的语法如下:

SELECT 目标表的列名或列表达式集合

FROM 基本表或(和)视图集合

〔WHERE条件表达式〕

〔GROUP BY列名集合

〔HAVING组条件表达式〕〕

〔ORDER BY列名〔集合〕…〕

整个语句的语义如下:从FROM子句中列出的表中,选择满足WHERE子句中给出的条件表达式的元组,然后按GROUPBY子句(分组子句)中指定列的值分组,再提取满足HAVING子句中组条件表达式的那些组,按SELECT子句给出的列名或列表达式求值输出。ORDER子句(排序子句)是对输出的目标表进行重新排序,并可附加说明ASC(升序)或DESC(降序)排列。

在WHERE子句中的条件表达式F中可出现下列 *** 作符和运算函数:

算术比较运算符:<,<=,>,>=,=,<>。

逻辑运算符:AND,OR,NOT。

集合运算符:UNION(并),INTERSECT(交),EXCEPT(差)。

集合成员资格运算符:IN,NOT IN

谓词:EXISTS(存在量词),ALL,SOME,UNIQUE。

聚合函数:AVG(平均值),MIN(最小值),MAX(最大值),SUM(和),COUNT(计数)。

F中运算对象还可以是另一个SELECT语句,即SELECT语句可以嵌套。

上面只是列出了WHERE子句中可出现的几种主要 *** 作,由于WHERE子句中的条件表达式可以很复杂,因此SELECT句型能表达的语义远比其数学原形要复杂得多。

下面,我们以上面所建立的三个基本表为例,演示一下SELECT的应用:

1无条件查询

例:找出所有学生的的选课情况

SELECT st_no,su_no

FROM score

例:找出所有学生的情况

SELECT

FROM student

“”为通配符,表示查找FROM中所指出关系的所有属性的值。

2条件查询

条件查询即带有WHERE子句的查询,所要查询的对象必须满足WHERE子句给出的条件。

例:找出任何一门课成绩在70以上的学生情况、课号及分数

SELECT UNIQUE studentst_class,studentst_no,studentst_name,studentst_sex,studentst_age,scoresu_no,scorescore

FROM student,score

WHERE scorescore>=70 AND scorestno=studentst_no

这里使用UNIQUE是不从查询结果集中去掉重复行,如果使用DISTINCT则会去掉重复行。另外逻辑运算符的优先顺序为NOT→AND→OR。

例:找出课程号为c02的,考试成绩不及格的学生

SELECT st_no

FROM score

WHERE su_no=‘c02’AND score<60

3排序查询

排序查询是指将查询结果按指定属性的升序(ASC)或降序(DESC)排列,由ORDER BY子句指明。

例:查找不及格的课程,并将结果按课程号从大到小排列

SELECT UNIQUE su_no

FROM score

WHERE score<60

ORDER BY su_no DESC

4嵌套查询

嵌套查询是指WHERE子句中又包含SELECT子句,它用于较复杂的跨多个基本表查询的情况。

例:查找课程编号为c03且课程成绩在80分以上的学生的学号、姓名

SELECT st_no,st_name

FROM student

WHERE stno IN (SELECT st_no

FROM score

WHERE su_no=‘c03’ AND score>80 )

这里需要明确的是:当查询涉及多个基本表时用嵌套查询逐次求解层次分明,具有结构程序设计特点。在嵌套查询中,IN是常用到的谓词。若用户能确切知道内层查询返回的是单值,那么也可用算术比较运算符表示用户的要求。

5计算查询

计算查询是指通过系统提供的特定函数(聚合函数)在语句中的直接使用而获得某些只有经过计算才能得到的结果。常用的函数有:

COUNT() 计算元组的个数

COUNT(列名) 对某一列中的值计算个数

SUM(列名) 求某一列值的总和(此列值是数值型)

AVG(列名) 求某一列值的平均值(此列值是数值型)

MAX(列名) 求某一列值中的最大值

MIN(列名) 求某一列值中的最小值

例:求男学生的总人数和平均年龄

SELECT COUNT(),AVG(st_age)

FROM student

WHERE st_sex=‘男’

例:统计选修了课程的学生的人数

SELECT COUNT(DISTINCT st_no)

FROM score

注意:这里一定要加入DISTINCT,因为有的学生可能选修了多门课程,但统计时只能按1人统计,所以要使用DISTINCT进行过滤。

##2 (三) 数据更新

数据更新包括数据插入、删除和修改 *** 作。它们分别由INSERT语句,DELETE语句及UPDATE语句完成。这些 *** 作都可在任何基本表上进行,但在视图上有所限制。其中,当视图是由单个基本表导出时,可进行插入和修改 *** 作,但不能进行删除 *** 作;当视图是从多个基本表中导出时,上述三种 *** 作都不能进行。

1数据插入

将数据插入SQL的基本表有两种方式:一种是单元组的插入,另一种是多元组的插入。

单元组的插入:向基本表score中插入一个成绩元组(100002,c02,95),可使用以下语句:

INSERT INTO score(st_no,su_no,score) VALUES(‘100002’,‘c02’,95)

由此,可以给出单元组的插入语句格式:

INSERT INTO表名(列名1〔,列名2〕…) VALUES(列值1〔,列值2〕…)

其中,列名序列为要插入值的列名集合,列值序列为要插入的对应值。若插入的是一个表的全部列值,则列名可以省略不写如上面的(st_no,su_no,score)可以省去;若插入的是表的部分列值,则必须列出相应列名,此时,该关系中未列出的列名取空值。

多元组的插入:这是一种把SELECT语句查询结果插入到某个已知的基本表中的方法。

例如:需要在表score中求出每个学生的平均成绩,并保留在某个表中。此时可以先创建一个新的基本表stu_avggrade,再用INSERT语句把表score中求得的每一个学生的平均成绩(用SELECT求得)插入至stu_avggrade中。

CREATE TABLE stu_avggrade

(st_no CHAR(10) NOT NULL,//定义列st_no学号,类型为10位定长字符串,非空

age_grade SMALLINT NOT NULL )// 定义列age_grade平均分,类型为短整形,非空

INSERT INTO stu_avggrade(st_no,age_grade)

SELECT st_no,AVG(score)

FROM score

GROUP BY st_no //因为要求每一个学生所有课程的平均成绩,必须按学号分组进行计算。

2数据删除

SQL的删除 *** 作是指从基本表中删除满足WHERE<条件表达式>的记录。如果没有WHERE子句,则删除表中全部记录,但表结构依然存在。其语句格式为:

DELETE FROM表名〔WHERE 条件表达式〕

下面举例说明:

单元组的删除:把学号为100002的学生从表student中删除,可用以下语句:

DELETE FROM student

WHERE st_no=‘100002’//因为学号为100002的学生在表student中只有一个,所以为单元组的删除

多元组的删除:学号为100002的成绩从表score中删除,可用以下语句:

DELETE FROM score

WHERE st_no=‘100002’//由于学号为100002的元组在表score中可能有多个,所以为多元组删除

带有子查询的删除 *** 作:删除所有不及格的学生记录,可用以下语句

DELETE FROM student

WHERE st_no IN

(SELETE st_no

FROM score

WHERE score<60)

3数据修改

修改语句是按SET子句中的表达式,在指定表中修改满足条件表达式的记录的相应列值。其语句格式如下:

UPDATE 表名 SET 列名=列改变值〔WHERE 条件表达式〕

例:把c02的课程名改为英语,可以用下列语句:

UPDATE subject

SET su_subject=‘英语’

WHERE su_no=‘c02’

例:将课程成绩达到70分的学生成绩,再提高10%

UPDATE score

SET score=11score

WHERE score>=70

SQL的删除语句和修改语句中的WHERE子句用法与SELECT中WHERE子句用法相同。数据的删除和修改 *** 作,实际上要先做SELECT查询 *** 作,然后再把找到的元组删除或修改。

##2 (四) 数据控制

由于数据库管理系统是一个多用户系统,为了控制用户对数据的存取权利,保持数据的共享及完全性,SQL语言提供了一系列的数据控制功能。其中,主要包括安全性控制、完整性控制、事务控制和并发控制。

1安全性控制

数据的安全性是指保护数据库,以防非法使用造成数据泄露和破坏。保证数据安全性的主要方法是通过对数据库存取权力的控制来防止非法使用数据库中的数据。即限定不同用户 *** 作不同的数据对象的权限。

存取权控制包括权力的授与、检查和撤消。权力授与和撤消命令由数据库管理员或特定应用人员使用。系统在对数据库 *** 作前,先核实相应用户是否有权在相应数据上进行所要求的 *** 作。

(1)权力授与:权力授与有数据库管理员专用的授权和用户可用的授权两种形式。数据库管理员专用授权命令格式如下:

|CONNECT |

GRANT|RESOURCE|TO 用户名〔IDENTIFED BY 口令〕

|DBA |

其中,CONNECT表示数据库管理员允许指定的用户具有连接到数据库的权力,这种授权是针对新用户;RESOURCE表示允许用户建立自己的新关系模式,用户获得CONNECT权力后,必须获得RESOURCE权力才能创建自己的新表;DBA表示数据库管理员将自己的特权授与指定的用户。若要同时授与某用户上述三种授权中的多种权力,则必须通过三个相应的GRANT命令指定。

另外,具有CONNECT和RESOURCE授权的用户可以建立自己的表,并在自己建立的表和视图上具有查询、插入、修改和删除的权力。但通常不能使用其他用户的关系,除非能获得其他用户转授给他的相应权力。

例:若允许用户SSE连接到数据库并可以建立他自己的关系,则可通过如下命令授与权力:

GRANT CONNECT TO SSE INENTIFIED BY BD1928

GRANT RESOURCE TO SSE

用户可用的授权是指用户将自己拥有的部分或全部权力转授给其他用户的命令形式,其命令格式如下:

|SELECT |

|INSERT |

|DELETE |

GRANT|UPDATE(列名1[,列名2]…)|ON|表名 |TO|用户名|〔WITH GRANT OPTION〕

|ALTER | |视图名| |PUBLIC|

|NDEX |

|ALL |

若对某一用户同时授与多种 *** 作权力,则 *** 作命令符号可用“,”相隔。

PUBLIC 表示将权力授与数据库的所有用户,使用时要注意:

任选项WITH GRANT OPTION表示接到授权的用户,具有将其所得到的同时权力再转授给其他用户权力。

例:如果将表student的查询权授与所有用户,可使用以下命令:

GRANT SELECT ON student TO PUBLIC

例:若将表subject的插入及修改权力授与用户SSE并使得他具有将这种权力转授他人的权力,则可使用以下命令:

GRANT INSERT,UPDATE(su_subject) ON subject TO SSE WITH GRANT OPTION

这里,UPDATE后面跟su_subject是指出其所能修改的列。

(2)权力回收:权力回收是指回收指定用户原已授与的某些权力。与权力授与命令相匹配,权力回收也有数据库管理员专用和用户可用的两种形式。

DBA专用的权力回收命令格式为:

|CONNECT |

REVOKE|RESOURCE|FROM用户名

|DBA |

用户可用的权力回收命令格式为:

|SELECT |

|INSERT |

|DELETE |

REVOKE|UPDATE(列名1〔,列名2〕…) |ON|表名 |FROM |用户名|

|ALTER | |视图名| |PUBLIC|

|INDEX |

|ALL |

例:回收用户SSE的DBA权力:

REVOKE DBA FROM SSE

2完整性控制

数据库的完整性是指数据的正确性和相容性,这是数据库理论中的重要概念。完整性控制的主要目的是防止语义上不正确的数据进入数据库。关系系统中的完整性约束条件包括实体完整性、参照完整性和用户定义完整性。而完整性约束条件的定义主要是通过CREATE TABLE语句中的〔CHECK〕子句来完成。另外,还有一些辅助命令可以进行数据完整性保护。如UNIQUE和NOT NULL,前者用于防止重复值进入数据库,后者用于防止空值。

3事务控制

事务是并发控制的基本单位,也是恢复的基本单位。在SQL中支持事务的概念。所谓事务,是用户定义的一个 *** 作序列(集合),这些 *** 作要么都做,要么一个都不做,是一个不可分割的整体。一个事务通常以BEGIN TRANSACTION开始,以COMMIT或ROLLBACK结束。

SQL提供了事务提交和事务撤消两种命令:

(1)事务提交:事务提交的命令为:

COMMIT 〔WORK〕

事务提交标志着对数据库的某种应用 *** 作成功地完成,所有对数据库的 *** 作都必须作为事务提交给系统时才有效。事务一经提交就不能撤消。

(2)事务撤消:事务撤消的命令是:

ROLLBACK 〔WORK〕

事务撤消标志着相应事务对数据库 *** 作失败,因而要撤消对数据库的改变,即要“回滚”到相应事务开始时的状态。

当系统非正常结束时(如掉电、系统死机),将自动执行ROLLBACK命令

SQL还提供了自动提交事务的机制,其命令为:

SET AUTO COMMIT ON

其对应的人工工作方式命令为:

三层架构可以说是一种设置模式,他的作用只是让我们更加有效的利用资源,有利于以后的修改和查看,依次分为视图层,逻辑层,数据层;

试图层顾名思义就是我们所看到的,他的原代码并没有关于处理和连库等代码,只是简单的跳转页面,我们没有办法看到真正的代码;

逻辑层就是我们从页面层发回的问题等请求,从字面意思来看,你可以将他视为一个过渡层,只是连接是图层和数据层;进行一些连库,删除数据等 *** 作了;从试图层跳转过来的问题在这里进行处理,并提交给数据层,再返回页面层共读者查看;

数据层就不用说了吧!这里存放着所有的数据也就是一个工程的大本营一样;

三层架构已经不仅仅属于net了,他是一种设计形式,从某种意义上来说,所有的开发设计几乎都已经以三层架构为基础,三层架构及有效的处理问题,将数据和试图也有效的分开,这样防止耦合度过高,有利于处理和修改,(你不会是想将代码全部写在视图页面上,这样有一个小小的变动,我们就要翻看几十万句代码,从中找出,那我要替你的眼睛抱不平了)当你将程序做好后,从这台机子移动到另一台机子时,大大减少了出错的问题;

通俗一点就是,这样看上去很有层次感,我们查看时,可以减少时间的浪费,也不用在代码堆里翻来覆去找不到北

以上就是关于《高并发Oracle数据库系统的架构与设计》epub下载在线阅读全文,求百度网盘云资源全部的内容,包括:《高并发Oracle数据库系统的架构与设计》epub下载在线阅读全文,求百度网盘云资源、myscl数据库架构是什么、关于数据库系统等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9719837.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-01
下一篇 2023-05-01

发表评论

登录后才能评论

评论列表(0条)

保存