Oracle 存储过程

Oracle 存储过程

  1. CREATEOR REPLACE PROCEDURE [procedure_name] IS ... 主体格式:
  • IS:用于分隔存储过程的头部声明部分和主体逻辑部分的开始。
  • CREATE OR REPLACE PROCEDURE:用于创建或替换已存在的存储过程。

image.png

  1. SELECT ... INTO 变量名:在 Oracle PL/SQL 中,**SELECT ... INTO**语句用于将查询结果存储到一个或多个变量中。

image.png

  1. FOR UPDATE:此子句将锁定符合 WHERE 条件的行,以便在事务中更新这些行的数据。在数据库中执行 FOR UPDATE 时,会锁定选中的行,以防止其他事务并发修改这些行。

image.png

  1. || 是字符串连接操作符 。

image.png

  1. := 是赋值操作符。

image.png

  1. RETURNING 子句:RETURNING 子句用于获取 INSERT、UPDATE 或 DELETE 操作影响的行,并返回指定列的值 ,一般配合into使用。

image.png

  1. sql%rowcount: 是一个 SQL 内置的伪列,它用于获取最近一个 SQL 语句影响的行数。在 PL/SQL 中,可以通过 sql%rowcount 来获取上一个 SQL 语句执行后受影响的行数,并将这个值赋给一个变量。

image.png

💡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(某个游标类型) 等等。

image.png

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xupengboo

你的鼓励将是我创作最大的动力。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值