Oracle 存储过程

Oracle 存储过程

  1. CREATEOR REPLACE PROCEDURE [procedure_name] IS ... 主体格式:
  • IS:用于分隔存储过程的头部声明部分和主体逻辑部分的开始。
  • CREATE OR REPLACE PROCEDURE:用于创建或替换已存在的存储过程。
  1. SELECT ... INTO 变量名 :在 Oracle PL/SQL 中,**SELECT ... INTO**语句用于将查询结果存储到一个或多个变量中。
  1. FOR UPDATE:此子句将锁定符合 WHERE 条件的行,以便在事务中更新这些行的数据。在数据库中执行 FOR UPDATE 时,会锁定选中的行,以防止其他事务并发修改这些行。
  1. || 是字符串连接操作符 。
  1. := 是赋值操作符。
  1. RETURNING 子句 :RETURNING 子句用于获取 INSERT、UPDATE 或 DELETE 操作影响的行,并返回指定列的值 ,一般配合into使用。
  1. sql%rowcount: 是一个 SQL 内置的伪列,它用于获取最近一个 SQL 语句影响的行数。在 PL/SQL 中,可以通过 sql%rowcount 来获取上一个 SQL 语句执行后受影响的行数,并将这个值赋给一个变量。

💡Tips: "内置的伪列"(pseudo column)指的是一类特殊的列,它们不是实际存储在表中的数据列,而是由数据库系统提供的特殊值或信息。这些伪列在 SQL 查询中可以像普通列一样使用,但它们的值通常是根据当前执行的上下文或者特定规则计算得到的,而不是存储在表中的实际数据。

  1. BEGIN ... END:是用来定义一个块(block)的语法结构 , 这个块可以包含一系列的语句和程序逻辑,类似于其他编程语言中的代码块或者函数体。
  • 逻辑分组 :BEGIN ... END 可以将多条语句组织在一起,形成一个逻辑上的整体。 这些语句可以是变量声明、条件判断、循环、SQL 操作等,用于完成特定的任务或逻辑流程。
  • 错误处理:BEGIN ... END 块经常用于实现错误处理逻辑。通过捕获和处理异常,可以在 BEGIN 块中编写可能触发异常的代码,然后在 EXCEPTION 块中定义异常处理方式。
  • 事务控制:BEGIN ... END 块可以作为事务的一部分。在块的开始和结束之间执行的 SQL 操作,将作为一个原子操作提交或回滚,以确保数据的一致性和完整性。
  1. %TYPE:是一个类型属性限定符,它可以用来声明一个变量、参数或表列的数据类型,以确保数据类型的一致性,并且在数据模型发生变化时可以自动同步更新。
  • 还包括:BAS_ITEM%ROWTYPE(某一行)SYS_REFCURSOR(某个游标类型) 等等。
相关推荐
素材积累1 小时前
博士后出站来深可申请的项目补贴等
数据库
_1_73 小时前
SQL Server 磁盘满了 收缩日志
数据库·sqlserver
basketball6163 小时前
Redis基础:1. Redis介绍
数据库·redis·缓存
李可以量化3 小时前
成交量的终极量化策略:价量共振指标完整实现(下篇)
前端·数据库·人工智能
汽车仪器仪表相关领域4 小时前
南华 NHAT-610 柴油车排放测试仪 产品详解
数据库·功能测试·汽车·压力测试·可用性测试
我滴老baby6 小时前
工业时序数据实战:基于 DolphinDB 流计算引擎的实现与调优
数据库
睡不醒男孩0308236 小时前
TiDB数据库调研
数据库·tidb
珠***格6 小时前
实操落地|防逆流装置的安装规范、调试标准与故障处置
网络·数据库·人工智能·分布式·能源·边缘计算
Omics Pro7 小时前
3种蛋白结构输入方式!已申报欧洲发明专利
数据库·人工智能·python·机器学习·plotly
itfallrain8 小时前
Spring 构造器循环依赖排查:@RequiredArgsConstructor + @Lazy 到底有没有生效
数据库·python·spring