Oracle中的 plsql语法

01-plsql

为什么要plsql

  • 复杂的业务逻辑 可以使用 编程语言实现 sql无法实现

  • plsql也可以实现复杂的业务逻辑

    • 为不直接使用编程语言 而是学习plsql

    • plsql会比直接使用 编程语言 速度更快

基本语法:

declare --声明变量 变量名 变量类型

begin

--代码逻辑

end;

02-select into赋值方法

语法:

复制代码
select  列名   into    变量名  from  表名  where  条件
  • 注意

    • select 后的字段数量 和 变量数量保持一致(类型尽量保持一致)

    • select into这种方式 只能获取一行数据

03-引用变量

变量类型 使用表中的字段的类型的

  • 变量类型 会随着 表中的类型变化而变化

语法:

v_num1 T_ACCOUNT.num1%type;

04-行变量

行变量 获取一行数据

  • 行变量可以获取一行中的任意的字段

05-异常处理

程序出现bug 需要进行调整

  • 不希望 程序直接崩溃

  • 给出bug的原因

语法

exception

when 错误类型 then

处理异常;

when others then

所有的异常

-- 其他异常 others

-- sqlcode错误代码

-- sqlerrm错误信息

06-游标

  • 记录数据获取的位置

  • 存储每一行数据

语法:

-- 创建游标语法:

-- cursor 游标名称 is SQL语句;

-- 使用游标语法:

-- open 游标名称

-- loop

-- 业务逻辑

-- fetch 游标名称 into 变量

-- exit when 游标名称%notfound

-- 业务逻辑

-- end loop;

-- close 游标名称

07-索引

作用

  • 加快查询速度

  • 索引是一个特殊的文件(字典的目录)

语法

-- create index 索引名 on 表名(索引字段);

create index index_test on t_index_test(name);

-- 主键就是唯一索引

相关推荐
七七七七0717 小时前
【Redis】Ubuntu22.04安装redis++
数据库·redis·缓存
子非鱼92117 小时前
MyBatisPlus快速上手
数据库·spring boot·mybatisplus
DBA小马哥17 小时前
从传统数据库到金仓数据库:时序数据迁移的挑战与解决方案
数据库·时序数据库·dba
什么都不会的Tristan17 小时前
redis-原理篇-Dict
数据库·redis·缓存
数据知道18 小时前
亿级图片链接存入 PostgreSQL,URL链接字段数据类型用哪个最合适?
数据库·postgresql
马克学长18 小时前
SSM学生综合素质评价系统wy345(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·学生综合素质评价系统·家校协同
煎蛋学姐18 小时前
SSM学生宿舍管理系统a55l1(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·学生宿舍管理系统·ssm 框架
xuefuhe18 小时前
PG权限privilege
数据库
重生之绝世牛码18 小时前
Linux软件安装 —— Redis集群安装(三主三从)
大数据·linux·运维·数据库·redis·数据库开发·软件安装
知识分享小能手18 小时前
Oracle 19c入门学习教程,从入门到精通,Oracle 过程、函数、触发器和包详解(7)
数据库·学习·oracle