文档库 最新最全的文档下载
当前位置:文档库 › 2020年(Oracle管理)华为oracle培训教材

2020年(Oracle管理)华为oracle培训教材

2020年(Oracle管理)华为oracle培训教材
2020年(Oracle管理)华为oracle培训教材

(Oracle管理)华为oracle培训教材

SQL语言简介

1、SQL概述

SQL是一种面向数据库的通用数据处理语言规范,能完成以下几类功能:提取查询数据,插入修改删除数据,生成修改和删除数据库对象,数据库安全控制,数据库完整性及数据保护控制。

数据库对象包括表、视图、索引、同义词、簇、触发器、函数、过程、包、数据库链、快照等(表空间、回滚段、角色、用户)。数据库通过对表的操作来管理存储在其中的数据。

1)SQL*PLUS界面:

登录:输入SQLPLUS回车;输入正确的ORACLE用户名并回车;输入用户口令并回车,显示提示符:SQL>

退出:输入EXIT即可。

2)命令的编辑与运行:

●在命令提示符后输入SQL命令并运行,以分号结束输入;以斜杠结束输入;以空行结束输入;

●利用SQL缓冲区进行PL/SQL块的编辑和运行;

●利用命令文件进行PL/SQL块的编辑和运行。

2、数据库查询

1)用SELECT语句从表中提取查询数据。语法为

SELECT[DISTINCT]{column1,column2,…}FROMtablenameWHERE{conditi ons}GROUPBY{conditions}ORDERBY{expressions}[ASC/DESC];

说明:SELECT子句用于指定检索数据库的中哪些列,FROM子句用于指定从哪一个表或视图中检索数据。

2)SELECT中的操作符及多表查询WHERE子句。(LIKE,IS,…) WHERE子句中的条件可以是一个包含等号或不等号的条件表达式,也可以是一个含有IN、NOTIN、BETWEEN、LIKE、ISNOTNULL等比较运算符的条件式,还可以是由单一的条件表达通过逻辑运算符组合成复合条件。

3)ORDERBY子句

ORDERBY子句使得SQL在显示查询结果时将各返回行按顺序排列,返回行的排列顺序由ORDERBY子句指定的表达式的值确定。

4)连接查询

利用SELECT语句进行数据库查询时,可以把多个表、视图的数据结合起来,使得查询结果的每一行中包含来自多个表达式或视图的数据,这种操作被称为连接查询。

连接查询的方法是在SELECT命令的FROM子句中指定两个或多个将被连接查询的表或视图,并且在WHERE子句告诉ORACLE如何把多个表的数据进行合并。根据WHERE子句中的条件表达式是等还是不等式,可以把连接查询分为等式连接和不等式连接。

5)子查询

如果某一个SELECT命令(查询1)出现在另一个SQL命令(查询2)的一个子句中,则称查询1是查询2的子查询。

3、基本数据类型(NUMBER,VARCHAR2,DATE)O

RACEL支持下列内部数据类型:

●VARCHAR2变长字符串,最长为2000字符。

●NUMBER数值型。

●LONG变长字符数据,最长为2G字节。

●DATE日期型。

●RAW二进制数据,最长为255字节。

●LONGRAW变长二进制数据,最长为2G字节。

●ROWID二六进制串,表示表的行的唯一地址。

●CHAR定长字符数据,最长为255。

4、常用函数用法:

一个函数类似于一个算符,它操作数据项,返回一个结果。函数在格式上不同于算符,它个具有变元,可操作0个、一个、二个或多个变元,形式为:

函数名(变元,变元,…)

函数具有下列一般类形:

●单行函数

●分组函数

1)单行函数对查询的表或视图的每一行返回一个结果行。它有数值函数,字符函数,日期函数,转换函数等。

2)分组函数返回的结果是基于行组而不是单行,所以分组函数不同于单行函数。在许多分组函数中可有下列选项:

●DISTRNCT该选项使分组函数只考虑变元表达式中的不同值。

●ALL该选项使分组函数考虑全部值,包含全部重复。

全部分组函数(除COUNT(*)外)忽略空值。如果具有分组函数的查询,没有返回行或只有空值(分组函数的变元取值的行),则分组函数返回空值。

5、数据操纵语言命令:

数据库操纵语言(DML)命令用于查询和操纵模式对象中的数据,它不隐式地提交当前事务。它包含UPDATE、INSERT、DELETE、EXPLAINPLAN、SELECT 和LOCKTABLE等命令。下面简单介绍一下:

1)UPDATEtablenameSET{column1=expression1,column2=expression2,…} WHERE{conditions};

例如:SQL>UPDATEEMP

SETJOB=’MANAGER’

WHEREENAME=’MAPTIN’;

SQL>SELECT*FROMEMP;

UPDATE子句指明了要修改的数据库是EMP,并用WHERE子句限制了只对名字(ENAME)为’MARTIN’的职工的数据进行修改,SET子句则说明修改的方式,即把’MARTION’的工作名称(JOB)改为’MARAGER’.

2)INSERTINTOtablename{column1,column2,…}VALUES{expression1,expr ession2,…};

例如:SQL>SELECTINTODEPT(DNAME,DEPTNO)

VALUES(‘ACCOUNTING’,10)

3)DELETEFROMtablenameWHERE{conditions};

例如:SQL>DELETEFROMEMP

WHEREEMPNO=7654;

DELETE命令删除一条记录,而且DELETE命令只能删除整行,而不能删除某行中的部分数据.

4)事务控制命令

提交命令(COMMIT):可以使数据库的修改永久化.设置AUTOCOMMIT为允许状态:SQL>SETAUTOCOMMITON;

回滚命令(ROLLBACK):消除上一个COMMIT命令后的所做的全部修改,使得数据库的内容恢复到上一个COMMIT执行后的状态.使用方法是:

SQL>ROLLBACK;

5、创建表、视图、索引、同义词、用户。

1)、表是存储用户数据的基本结构。

建立表主要指定义下列信息:

●列定义

●完整性约束

●表所在表空间

●存储特性

●可选择的聚集

●从一查询获得数据

语法如下:CREATETABLEtablename

(column1datatype[DEFAULTexpression][constraint],

column1datatype[DEFAULTexpression][constraint],

……)

[STORAGE子句]

[其他子句…];

例如:

SQL>CREATETABLENEW_DEPT

(DPTNONUMBER(2),

DNAMECHAR(6),

LOCCHAR(13);

更改表作用:

●增加列

●增加完整性约束

●重新定义列(数据类型、长度、缺省值)

●修改存储参数或其它参数

●使能、使不能或删除一完整性约束或触发器

●显式地分配一个范围

2)、视图

视图是一个逻辑表,它允许操作者从其它表或视图存取数据,视图本身不包含数据。视图所基于的表称为基表。

引入视图有下列作用:

●提供附加的表安全级,限制存取基表的行或/和列集合。

●隐藏数据复杂性。

●为数据提供另一种观点。

●促使ORACLE的某些操作在包含视图的数据库上执行,而不在另一个数据库上执行。

3)、索引

索引是种数据库对象。对于在表或聚集的索引列上的每一值将包含一项,为行提供直接的快速存取。在下列情况ORACLE可利用索引改进性能:

●按指定的索引列的值查找行。

●按索引列的顺序存取表。

建立索引:CREATE[UNIQUE]INDEXindexnameONtablename(column,。。。);例如:SQL>CREATINDEXIC_EMP

ONCLUSTEREMPLOYEE

4)、同义词

同义词:为表、视图、序列、存储函数、包、快照或其它同义词的另一个名字。使用同义词为了安全和方便。对一对象建立同义词可有下列好处:

●引用对象不需指出对象的持有者。

●引用对象不需指出它所位于的数据库。

●为对象提供另一个名字。

建立同义词:

CREATESYNONYMsymnon_nameFOR[username.]tablename;

例如:CREATPUBLICSYNONYMEMP

FORSCOTT.EMP@SALES

5)、用户CREATEUSERusernameIDENTIFIEDBYpassword;

例如:SQL>CREATEUSERSIDNEY

IDENTIFIEDBYCARTON;

Oracle扩展PL/SQL简介

1、PL/SQL概述。

PL/SQL是Oracle对SQL规范的扩展,是一种块结构语言,即构成一个PL/SQL

程序的基本单位(过程、函数和无名块)是逻辑块,可包含任何数目的嵌套了快。这种程序结构支持逐步求精方法解决问题。一个块(或子块)将逻辑上相关的说明和语句组合在一起,其形式为: DECLARE ---说明 BEGIN ---语句序列 EXCEPTION ---例外处理程序 END ; 它有以下优点: ● 支持SQL; ● 生产率高; ● 性能好; ● 可称植性; ● 与ORACLE 集成.

2、 PL/SQL 体系结构

PL/SQL 运行系统是种技术,不是一种独立产品,可认为这种技术是PL/SQL 块和子程序的一种机,它可接收任何有效的PL/SQL 块或子程序。如图所示:

PL/SQL 机可执行过程性语句,而将SQL 语句发送到ORACLE 服务器上的

SQL

语句执行器。在ORACLE预编译程序或OCI程序中可嵌入无名的PL/SQL块。如果ORACLE具有PROCEDURAL选件,有名的PL/SQL块(子程序)可单独编译,永久地存储在数据库中,准备执行。

3、PL/SQL基础:

PL/SQL有一字符集、保留字、标点、数据类型、严密语法等,它与SQL有相同表示,现重点介绍。

1)、数据类型:如下表所示

2)、变量和常量

在PL/SQL程序中可将值存储在变量和常量中,当程序执行时,变量的值可以改变,而常量的值不能改变。

3)、程序块式结构:

DECLARE

变量说明部分;

BEGIN

执行语句部分;

[EXCEPTION

例外处理部分;]

END;

4、控制语句:

分支语句:

IFconditionTHEN

Sequence_of_statements;

ENDIF;

IFconditionTHEN

Sequence_of_statement1;

ELSE

Sequence_of_statement2;

ENDIF;

IFcondition1THEN

Sequence_of_statement1;

ELSIFcondition2THEN

Sequence_of_statement2;

ELSIFcondition3THEN

Sequence_of_statement3;

ENDIF;

5、循环语句:

LOOP

Sequence_of_statements;

IFconditionTHEN

EXIT;

ENDIF;

ENDLOOP;

WHILEconditionLOOP

Sequence_of_statements;

ENDLOOP;

FORcounterINlower_bound..higher_boundLOOP Sequence_of_statements;

ENDLOOP;

6、子程序:

存储过程:

CREATEPROCEDURE过程名(参数说明1,参数说明2,。。。)IS [局部说明]

BEGIN

执行语句;

END过程名;

存储函数:

CREATEFUNCTION函数名(参数说明1,参数说明2,。。。) RETURN类型IS

[局部说明]

BEGIN

执行语句;

END函数名;

相关文档