Oracle数据库 中的基础的一些语法结构
方括号里的内容为可选项
- 大括号是必填
1PL/SQL结构块
- DECLARE
- /*
- * 声明部分——定义常量、变量、复杂数据类型、游标、用户自定义异常
- */
- BEGIN
- /*
- * 执行部分——PL/SQL语句和SQL语句
- */
- EXCEPTION
- /*
- * 异常处理部分——处理运行异常
- */
- END;
- /*块结束标记 */
2 创建序列
- CREATE SEQUENCE [ schema. ] sequence_name
- [ { INCREMENT BY | START WITH } integer
- | { MAXVALUE integer | NOMAXVALUE }
- | { MINVALUE integer | NOMINVALUE }
- | { CYCLE | NOCYCLE }
- | { CACHE integer | NOCACHE }
- | ...
- ]...
- ;
- schema:模式,即用户名称
- sequence_name:序列名称
- INCREMENT BY:定义序列的步长,如果省略,则默认为1,如果出现负值,则代表Oracle序列的值是按照此步长递减的。
- START WITH:定义序列的初始值,默认为1。
- MAXVALUE:序列生成器能产生的最大值。NOMAXVALUE是默认选项,代表没有最大值定义。
- MINVALUE:序列生成器能产生的最小值。NOMINVALUE是默认选项,代表没有最小值定义。
- CYCLE和NOCYCLE:当序列生成器的值达到限制值后是否循环。CYCLE代表循环,NOCYCLE代表不循环。如果循环,则当递增序列达到最大值时,循环到最小值,最小值为1。对于递减序列达到最小值时,循环到最大值。如果不循环,达到限制值后,继续产生新值就会发生错误。
- CACHE:定义存放序列的内存块的大小,默认为20,相当于预加载。缓冲部分序列计数以便更快获取序列值,可以改善序列的性能,但缓存选项可能会造成数据丢失。NOCACHE表示不缓冲
3 删除序列
DROP SEQUENCE [ schema. ] sequence_name ;
4 修改序列
- ALTER SEQUENCE [ schema. ] sequence_name
- { INCREMENT BY integer
- | { MAXVALUE integer | NOMAXVALUE }
- | { MINVALUE integer | NOMINVALUE }
- | { CYCLE | NOCYCLE }
- | { CACHE integer | NOCACHE }
- | ...
- } ...
- ;
注意,不能修改序列的初始值,否则会报ORA-02283。如果需要修改初始值,先删除序列再重新创建序列设定初始值。
复合数据类型
5.1. 记录(Record)
- TYPE record_name IS RECORD(
- varable1 data_type1 [NOT NULL] [:= default_value ],
- varable2 data_type2 [NOT NULL] [:= default_value ],
- ......,
- varablen data_typen [NOT NULL] [:= default_value ]
- );
5.2. 表(TABLE)
5.2.1. 索引表
- TYPE table_name IS TABLE OF element_type [NOT NULL]
- INDEX BY [BINARY_INTEGER | PLS_INTEGER | VARCHAR2];
5.2.2 嵌套表
TYPE type_name IS TABLE OF element_type;
5.3. 数组(VARRAY)
TYPE varray_name IS VARRAY(size) OF element_type [NOT NULL];
6 显式游标
6.1声明/定义游标
- CURSOR cursor_name
- [(parameter_dec [, parameter_dec ]…)]
- [RETURN datatype]
- IS
- select_statement;
6.2 打开游标
OPEN cursor_name [ ( cursor_parameter [ [,] actual_cursor_parameter ]... ) ]
6.3读取数据
- FETCH { cursor | cursor_variable | :host_cursor_variable }
- { into_clause | bulk_collect_into_clause [ LIMIT numeric_expression ] } ;
6.4 关闭游标
CLOSE cursor_name;
7 游标FOR循环
- FOR index_variable IN cursor_name[(value[, value]…)] LOOP
- -- 游标处理语句
- END LOOP;
8条件结构
1. 简单IF结构
- -- 简单IF结构
- IF <布尔表达式> THEN
- 满足条件时执行的语句
- END IF;
2. IF-ELSE结构
- -- IF-ELSE结构
- IF <布尔表达式> THEN
- 满足条件时执行的语句
- ELSE
- 不满足条件时执行的语句
- END IF;
3 多重IF
- -- 多重IF
- IF <布尔表达式1> THEN
- 满足条件1时执行的语句
- ELSIF <布尔表达式2> THEN
- 满足条件2时执行的语句
- ELSIF <布尔表达式3> THEN
- 满足条件3时执行的语句
- ELSE
- 满足条件1、2、3均不满足时执行的语句
- END IF;
注意:ELSIF
不能写成ELSEIF
9 CASE
语法一
- CASE 条件表达式
- WHEN 条件表达式结果1 THEN
- 语句1
- WHEN 条件表达式结果2 THEN
- 语句2
- ......
- WHEN 条件表达式结果n THEN
- 语句n
- [ELSE 条件表达式结果]
- END CASE;
语法二
- CASE
- WHEN 条件表达式1 THEN
- 语句1
- WHEN 条件表达式2 THEN
- 语句2
- ......
- WHEN 条件表达式n THEN
- 语句n
- [ELSE 语句]
- END CASE;
10 循环结构
简单循环
- LOOP
- 循环体语句;
- [EXIT WHEN <条件语句>]
- END LOOP;
WHILE 循环
- WHILE <布尔表达式> LOOP
- 循环体语句;
- END LOOP;
FOR循环
- [<<标签>>]
- FOR 循环计数器 IN [ REVERSE ] 下限 .. 上限 LOOP
- 循环体语句;
- END LOOP [<<标签>>];
11 异常处理通常放在PL/SQL程序的后部,语法结构为
- EXCEPTION
- WHEN { exception [ OR exception ]... | OTHERS }
- THEN statement [ statement ]...
11.1非预定义的异常处理
非预定义异常有错误号没有名字,处理的办法是:自己定义一个名字,绑定到错误号,捕获错误名。处理这类异常,首先必须对非预定义的Oracle异常进行定义。
如:
1 myexcp EXCEPTION;
- 然后使用EXCEPTION_INIT语句与标准的ORACLE错误联系起来,如:
2 PRAGMA EXCEPTION_INIT(myexcp,-02292);
- 说明:ORA-02292是违反完整性约束的错误代码。
11.2 定义异常
- 异常名称 EXCEPTION;
- PRAGMA EXCEPTION_INIT(异常的名字,错误号);
- 11.3抛出异常
- RAISE 异常的名称
- RAISE_APPLICATION_ERROR过程可用于创建用户定义的错误信息,可以在可执行部分和异常处理部分使用
- RAISE APPLICATION_ERROR(错误号,错误描述);
- 11.4 处理异常
- 1 EXCEPTION
- 2 WHEN { exception [ OR exception ]... | OTHERS }
- 3 THEN statement [ statement ]...
12. FORALL
使用FORALL,可以将多个DML批量发送给SQL引擎来执行,最大限度地减少上下文交互所带来的开销。
- FORALL index_name IN
- { lower_bound .. upper_bound
- | INDICES OF collection_name [ BETWEEN lower_bound AND upper_bound ]
- | VALUES OF index_collection
- }
- [ SAVE EXCEPTIONS ] dml_statement;
index_name:一个无需声明的标识符,作为集合下标使用。
lower_bound .. upper_bound:数字表达式,来指定一组连续有效的索引数字下限和上限。该表达式只需解析一次。
INDICES OF collection_name:用于指向稀疏数组的实际下标。跳过没有赋值的元素,例如被 DELETE 的元素,NULL 也算值。
VALUES OF index_collection_name:把该集合中的值当作下标,且该集合值的类型只能是 PLS_INTEGER/BINARY_INTEGER。
SAVE EXCEPTIONS:可选关键字,表示即使一些DML语句失败,直到FORALL LOOP执行完毕才抛出异常。可以使用SQL%BULK_EXCEPTIONS 查看异常信息。
dml_statement:静态语句,例如:UPDATE或者DELETE;或者动态(EXECUTE IMMEDIATE)DML语句
13存储过程
- CREATE [ OR REPLACE ] PROCEDURE [ schema. ] procedure_name
- [ ( parameter_declaration [, parameter_declaration ]... ) ]
- [ invoker_rights_clause ]
- { IS | AS }
- { [ declare_section ] body | call_spec | EXTERNAL} ;
procedure_name:过程名称。
parameter_declaration:参数声明
格式如下
- parameter_name [ [ IN ] datatype [ { := | DEFAULT } expression ]
- | { OUT | IN OUT } [ NOCOPY ] datatype
IN:输入参数。
OUT:输出参数。
IN OUT:输入输出参数。
invoker_rights_clause:这个过程使用谁的权限运行
as或is用于开始一个PL/SQL块
declare_section:声明部分。
body:过程块主体,执行部分。
一般只有在确认procedure_name过程是新过程或是要更新的过程时,才使用OR REPALCE关键字
13 创建函数
- CREATE [ OR REPLACE ] FUNCTION [ schema. ] function_name
- [ ( parameter_declaration [, parameter_declaration]... )
- ]
- RETURN datatype
- [ { invoker_rights_clause
- | DETERMINISTIC
- | parallel_enable_clause
- | RESULT_CACHE [ relies_on_clause ]
- }...
- ]
- { { AGGREGATE | PIPELINED } USING [ schema. ] implementation_type
- | [ PIPELINED ] { IS | AS } { [ declare_section ] body
- | call_spec
- | EXTERNAL
- }
- } ;
14 建立包规范
- CREATE [ OR REPLACE ] [ EDITIONABLE | NONEDITIONABLE ]
- PACKAGE [ schema. ] package_name
- [ invoker_rights_clause ]
- { IS | AS } item_list_1 END [ package_name ] ;
package_name:包名。
invoker_rights_clause:使用谁的权限运行
item_list_1:声明包的公用组件列表
- { type_definition -- 数据类型
- | cursor_declaration -- 游标
- | item_declaration -- 变量、常量等
- | function_declaration -- 函数
- | procedure_declaration -- 过程
- }
- [ { type_definition
- | cursor_declaration
- | item_declaration
- | function_declaration
- | procedure_declaration
- | pragma
- }
- ]...
15 建立包体
- CREATE [ OR REPLACE ] PACKAGE BODY [ schema. ] package_name
- { IS | AS }
- BEGIN statement [ statement | pragma ]...
- [ EXCEPTION exception_handler [ exception_handler ]... ]
- [ initialize_section ]
- END [ package_name ] ;
动态SQL 使用EXECUTE IMMEDIATE语句
- EXECUTE IMMEDIATE dynamic_sql_stmt
- [ { into_clause | bulk_collect_into_clause } [ using_clause ]
- | using_clause [ dynamic_returning_clause ]
- | dynamic_returning_clause
- ] ;
dynamic_sql_stmt:是代表一条SQL语句或一个PL/SQL块的字符串表达式。
into_clause:用于存放被选出的字段值的变量或被选出的行记录。格式如:
INTO { variable [, variable ]... | record )
using_clause:SQL或PL/SQL字符串中包括用于参数绑定的占位符时,该子句为占位符绑定值,也可用于返回值。输入bind_argument参数是一个表达式,它的值将被输入(IN模式)或输出(OUT模式)或输入输出(IN OUT模式)到动态SQL语句或是PL/SQL块中。一个输出bind_argument参数就是一个能保存动态SQL返回值的变量。格式如:
USING [ IN | OUT | IN OUT ] bind_argument
[ [,] [ [ IN | OUT | IN OUT ] bind_argument ]...
dynamic_returning_clause:指明用于存放返回值的变量或记录。格式如:
{ RETURNING | RETURN } { into_clause | bulk_collect_into_clause }
Oracle数据库 中的基础的一些语法结构的更多相关文章
- 收集Oracle数据库中的SQL基线信息(一)基础信息收集
Oracle数据库中的SQL基线信息,当数据库出现性能问题时,在业务无法提供相应业务信息时,通过对比SQL基线信息来查找SQL的变化. 查找数据库一天内运行次数大于5000次的sqlid select ...
- oracle数据库中提供的5种约束
约束作用:用来保持数据的完整性,防止无效数据进入到数据库中.oracle数据库中提供的5种约束,都是限定某个列或者列的组合的.1.主键约束(PRIMARY KEY):在一个表中能唯一的标识一行.主键可 ...
- Oracle数据库中序列(SEQUENCE)的用法详解
Oracle数据库中序列(SEQUENCE)的用法详解 在Oracle数据库中,序列的用途是生成表的主键值,可以在插入语句中引用,也可以通过查询检查当前值,或使序列增至下一个值.本文我们主要介绍了 ...
- oracle 数据库中(创建、解锁、授权、删除)用户
上文我们已经建立了名为orcl66的数据库. 想要在数据库中创建.修改用户需要我们以管理员权限登录到数据库中. 首先我们通过sqlplus命令登录连接数据库. 输入sqlplus命令--用户名: sy ...
- Oracle数据库中的变量
Oracle数据库中的变量 来源:https://blog.csdn.net/wahaa591/article/details/46772769 1.define(即host变量) define va ...
- 查看Oracle数据库中的执行计划
1.set autotrace traceonly命令 2.explain plan for命令 1)explain plan for select * from dual; 2)select * f ...
- 将Oracle数据库中的数据写入Excel
将Oracle数据库中的数据写入Excel 1.准备工作 Oracle数据库"TBYZB_FIELD_PRESSURE"表中数据如图: Excel模板(201512.xls): 2 ...
- --关于null在oracle数据库中是否参与计算,进行验证,
--关于null在oracle数据库中是否参与计算,进行验证,with td as (select null id,1 name from dual ),td1 as ( select null id ...
- Oracle数据库中SYS、SYSTEM、DBSNMP、SYSMAN四用户的区别
[转] SYS.SYSTEM.DBSNMP. Oracle 数据库中 SYS.SYSTEM.DBSNMP.SYSMAN 四用户的区别 用户: SYS 用户: SYS,默认密码为 CHANGE_ON ...
随机推荐
- Centos 7 安装 FFmpeg
Step 1: Update the system sudo yum install epel-release -y sudo yum update -y sudo shutdown -r now S ...
- Windows下常用的100个CMD指令以及常见的操作
gpedit.msc—–组策略 2. sndrec32——-录音机 3. Nslookup——-IP地址侦测器 ,是一个 监测网络中 DNS 服务器是否能正确实现域名解析的命令行工具. 它在 Wind ...
- 使用base64转码的方式上传图片
1.前端html代码 <input style="width:100%" onchange="loadpicture(1)" type="fil ...
- ASP .Net Core路由(Route) - 纸壳CMS的关键
关于纸壳CMS 纸壳CMS是一个开源免费的,可视化设计,在线编辑的内容管理系统.基于ASP .Net Core开发,插件式设计: GitHub:https://github.com/SeriaWei/ ...
- 【打印机】argox入门
立象dx4300打印机调试. 1 环境搭建 1.1 下载软件 登录 http://www.argox.com.cn/Pages/servicedownload.aspx 下载驱动和手册. 1.2 正常 ...
- openvswitch 源码分析 OVS_ACTION_ATTR_HASH action
1.在ovs_dp_process_packet中查找kernel缓存流表,查到后执行ovs_execute_actions->do_execute_actions,其中有个actions是OV ...
- openstack 创建虚拟机的时候报错: Failed to allocate the network(s), not rescheduling.].
错误: 实例 "test-gtj" 执行所请求操作失败,实例处于错误状态.: 请稍后再试 [错误: Build of instance 5ea8c935-ee07-4788-823 ...
- FreePascal - 如何在各个平台中安装CodeTyphon!
安装CodeTyphon的操作系统: win10 X64 企业版 Ubuntu16.04 X64 Mac OS 10.11 虚拟机: VMware® Workstation 12 Pro 12.5.2 ...
- “借刀杀人”之CSRF拿下盗图狗后台
最近我一个做贸易的朋友找到我,他发现自己拍摄的图片又被某个同行盗用了,而且是全站的图片基本都被盗用. 之前对方是引用他的图片链接,后面我给他做了防盗链解决了,现在对方是先下载图片,然后自己上传到服务器 ...
- webpack快速入门——如何安装webpack及注意事项
1.window+R键,输入cmd打开命令行工具,输入 mkdir XXXX(XX:文件夹名): 2.cd XXX 进入刚刚创建好的文件夹里,输入cnpm install -g webpack (安装 ...