1、ORACLE体系结构SQL语言简介142020年4月19日资料内容仅供参考,如有不当或者侵权,请联系本人改正或者删除。SQL语言简介1、 SQL概述SQL是一种面向数据库的通用数据处理语言规范, 能完成以下几类功能: 提取查询数据, 插入修改删除数据, 生成修改和删除数据库对象, 数据库安全控制, 数据库完整性及数据保护控制。数据库对象包括表、 视图、 索引、 同义词、 簇、 触发器、 函数、 过程、 包、 数据库链、 快照等( 表空间、 回滚段、 角色、 用户) 。数据库经过对表的操作来管理存储在其中的数据。1) SQL*PLUS界面: 登录: 输入SQLPLUS回车; 输入正确的ORACL
2、E用户名并回车; 输入用户口令并回车, 显示提示符: SQL退出: 输入EXIT即可。2) 命令的编辑与运行: l 在命令提示符后输入SQL命令并运行, 以分号结束输入; 以斜杠结束输入; 以空行结束输入; l 利用SQL缓冲区进行PL/SQL块的编辑和运行; l 利用命令文件进行PL/SQL块的编辑和运行。2、 数据库查询1) 用SELECT语句从表中提取查询数据。语法为SELECT DISTINCT column1,column2, FROM tablename WHERE conditions GROUP BY conditions ORDER BY expressions ASC/DE
3、SC; 说明: SELECT子句用于指定检索数据库的中哪些列, FROM子句用于指定从哪一个表或视图中检索数据。2) SELECT中的操作符及多表查询WHERE子句。(LIKE,IS,) WHERE子句中的条件能够是一个包含等号或不等号的条件表示式, 也能够是一个含有IN、 NOT IN、 BETWEEN、 LIKE、 IS NOT NULL等比较运算符的条件式, 还能够是由单一的条件表示经过逻辑运算符组合成复合条件。3) ORDER BY 子句ORDER BY 子句使得SQL在显示查询结果时将各返回行按顺序排列, 返回行的排列顺序由ORDER BY 子句指定的表示式的值确定。4) 连接查询利
4、用SELECT语句进行数据库查询时, 能够把多个表、 视图的数据结合起来, 使得查询结果的每一行中包含来自多个表示式或视图的数据, 这种操作被称为连接查询。连接查询的方法是在SELECT命令的FROM子句中指定两个或多个将被连接查询的表或视图, 而且在WHERE子句告诉ORACLE如何把多个表的数据进行合并。根据WHERE子句中的条件表示式是等还是不等式, 能够把连接查询分为等式连接和不等式连接。5) 子查询如果某一个SELECT命令( 查询1) 出现在另一个SQL命令( 查询2) 的一个子句中, 则称查询1是查询2的子查询。3、 基本数据类型( NUMBER,VARCHAR2,DATE) O
5、 RACEL支持下列内部数据类型: l VARCHAR2 变长字符串, 最长为 字符。l NUMBER 数值型。l LONG 变长字符数据, 最长为2G字节。l DATE 日期型。l RAW 二进制数据, 最长为255字节。l LONG RAW 变长二进制数据, 最长为2G字节。l ROWID 二六进制串, 表示表的行的唯一地址。l CHAR 定长字符数据, 最长为255。4、 常见函数用法: 一个函数类似于一个算符, 它操作数据项, 返回一个结果。函数在格式上不同于算符, 它个具有变元, 可操作0个、 一个、 二个或多个变元, 形式为: 函数名( 变元, 变元, ) 函数具有下列一般类形:
6、l 单行函数l 分组函数1) 单行函数对查询的表或视图的每一行返回一个结果行。它有数值函数, 字符函数, 日期函数, 转换函数等。2) 分组函数返回的结果是基于行组而不是单行, 因此分组函数不同于单行函数。在许多分组函数中可有下列选项: l DISTRNCT 该选项使分组函数只考虑变元表示式中的不同值。l ALL该选项使分组函数考虑全部值, 包含全部重复。全部分组函数( 除COUNT( *) 外) 忽略空值。如果具有分组函数的查询, 没有返回行或只有空值( 分组函数的变元取值的行) , 则分组函数返回空值。5、 数据操纵语言命令: 数据库操纵语言( DML) 命令用于查询和操纵模式对象中的数据
7、, 它不隐式地提交当前事务。它包含UPDATE、 INSERT、 DELETE、 EXPLAIN PLAN、 SELECT和LOCK TABLE 等命令。下面简单介绍一下: 1) UPDATE tablename SET column1=expression1,column2=expression2, WHERE conditions;例如: SQLUPDATE EMP SET JOB =MANAGER WHERE ENAME=MAPTIN; SQL SELECT * FROM EMP;UPDATE子句指明了要修改的数据库是EMP,并用WHERE子句限制了只对名字(ENAME)为MARTIN的
8、职工的数据进行修改,SET子句则说明修改的方式,即把MARTION的工作名称(JOB)改为MARAGER.2) INSERT INTO tablename column1,column2, VALUES expression1,expression2,;例如: SQLSELECT INTO DEPT( DNAME, DEPTNO) VALUES ( ACCOUNTING, 10) 3) DELETE FROM tablename WHERE conditions;例如: SQLDELETE FROM EMP WHERE EMPNO = 7654;DELETE命令删除一条记录,而且DELETE命
9、令只能删除整行,而不能删除某行中的部分数据.4) 事务控制命令提交命令(COMMIT):能够使数据库的修改永久化.设置AUTOCOMMIT为允许状态:SQL SET AUTOCOMMIT ON;回滚命令(ROLLBACK):消除上一个COMMIT命令后的所做的全部修改,使得数据库的内容恢复到上一个COMMIT执行后的状态.使用方法是:SQLROLLBACK;5、 创立表、 视图、 索引、 同义词、 用户。1) 、 表是存储用户数据的基本结构。建立表主要指定义下列信息: l 列定义l 完整性约束l 表所在表空间l 存储特性l 可选择的聚集l 从一查询获得数据 语法如下: CREATE TABLE
10、 tablename (column1 datatype DEFAULT expression constraint, column1 datatype DEFAULT expression constraint, ) STORAGE子句其它子句; 例如: SQLCREATE TABLE NEW_DEPT (DPTNO NUMBER(2), DNAME CHAR(6),LOC CHAR(13);更改表作用: l 增加列l 增加完整性约束l 重新定义列( 数据类型、 长度、 缺省值) l 修改存储参数或其它参数l 使能、 使不能或删除一完整性约束或触发器l 显式地分配一个范围2) 、 视图视图是
11、一个逻辑表, 它允许操作者从其它表或视图存取数据, 视图本身不包含数据。视图所基于的表称为基表。引入视图有下列作用: l 提供附加的表安全级, 限制存取基表的行或/和列集合。l 隐藏数据复杂性。l 为数据提供另一种观点。l 促使ORACLE的某些操作在包含视图的数据库上执行, 而不在另一个数据库上执行。 3) 、 索引 索引是种数据库对象。对于在表或聚集的索引列上的每一值将包含一项, 为行提供直接的快速存取。在下列情况ORACLE可利用索引改进性能: l 按指定的索引列的值查找行。l 按索引列的顺序存取表。 建立索引: CREATE UNIQUE INDEX indexname ON tabl
12、ename(column ,。); 例如: SQLCREAT INDEX IC_EMP ON CLUSTER EMPLOYEE4) 、 同义词同义词: 为表、 视图、 序列、 存储函数、 包、 快照或其它同义词的另一个名字。使用同义词为了安全和方便。对一对象建立同义词可有下列好处: l 引用对象不需指出对象的持有者。l 引用对象不需指出它所位于的数据库。l 为对象提供另一个名字。建立同义词: CREATE SYNONYM symnon_name FOR username.tablename;例如: CREAT PUBLIC SYNONYM EMP FOR SCOTT.EMP SALES 5)
13、、 用户CREATE USER username IDENTIFIED BY password;例如: SQLCREATE USER SIDNEY IDENTIFIED BY CARTON ;Oracle扩展PL/SQL简介1、 PL/SQL概述。PL/SQL是Oracle对SQL规范的扩展, 是一种块结构语言, 即构成一个PL/SQL程序的基本单位( 过程、 函数和无名块) 是逻辑块, 可包含任何数目的嵌套了快。这种程序结构支持逐步求精方法解决问题。一个块( 或子块) 将逻辑上相关的说明和语句组合在一起, 其形式为: DECLARE-说明BEGIN-语句序列EXCEPTION-例外处理程序E
14、ND; 它有以下优点:l 支持SQL;l 生产率高;l 性能好;l 可称植性;l 与ORACLE集成.2、 PL/SQL体系结构PL/SQL运行系统是种技术, 不是一种独立产品, 可认为这种技术是PL/SQL块和子程序的一种机, 它可接收任何有效的PL/SQL块或子程序。如图所示: PL/SQL机 过程性语句执行器PL/SQL块PL/SQL块SQL语句PL/SQL机可执行过程性语句, 而将SQL语句发送到ORACLE服务器上的SQL语句执行器。在ORACLE预编译程序或OCI程序中可嵌入无名的PL/SQL块。如果ORACLE具有PROCEDURAL选件, 有名的PL/SQL块( 子程序) 可单
15、独编译, 永久地存储在数据库中, 准备执行。3、 PL/SQL基础: PL/SQL有一字符集、 保留字、 标点、 数据类型、 严密语法等, 它与SQL有相同表示, 现重点介绍。1) 、 数据类型: 如下表所示数据类型子类型纯量类型数值BINARY_INTEGERNATURAL,POSITIVENUMBERDEC,DECIMAL,DOUBLE PRECISION,PLOAT,INTEGER,INT,NUMERIC,REAL,SMALLINT字符CHARCHARACTER,STRINGVARCHAR2VARCHARLONGLONG RAWRAWRAWID逻辑BOOLEAN日期DATE组合类型记录R
16、ECORD表TABLE2) 、 变量和常量在PL/SQL程序中可将值存储在变量和常量中, 当程序执行时, 变量的值能够改变, 而常量的值不能改变。3) 、 程序块式结构: DECLARE变量说明部分; BEGIN执行语句部分; EXCEPTION例外处理部分; END;4、 控制语句: 分支语句: IF condition THENSequence_of_statements;END IF;IF condition THENSequence_of_statement1;ELSESequence_of_statement2;END IF;IF condition1 THENSequence_of
17、_statement1;ELSIF condition2 THENSequence_of_statement2;ELSIF condition3 THENSequence_of_statement3;END IF;5、 循环语句: LOOPSequence_of_statements;IF condition THENEXIT;END IF;END LOOP; WHILE condition LOOPSequence_of_statements;END LOOP;FOR counter IN lower_bound.higher_bound LOOPSequence_of_statements;END LOOP;6、 子程序: 存储过程: CREATE PROCEDURE 过程名 (参数说明1, 参数说明2, 。) IS局部说明BEGIN执行语句; END 过程名; 存储函数: CREATE FUNCTION 函数名 (参数说明1, 参数说明2, 。)RETURN 类型 IS局部说明BEGIN执行语句; END 函数名;