pl/sql程序块的使用

sql 复制代码
-- Created on 2024-01-15 by ADMINISTRATOR 
declare 
  -- Local variables here
  record_tablename varchar2(100);---test_record表名
  record_StartNo integer(19);---test_record开始编号
  temp_No        integer(19);
  maxnbbh        integer(19);
  nCnt           integer := 20;
  finalStep_StartNo integer(19);---test_record开始编号
begin
  record_tablename := 'test_record';
  -- Test statements here
  getmaxid(record_tablename, nCnt, record_StartNo);---调用存储过程getmaxid
  dbms_output.put_line(record_StartNo);
  <<looplabel>>---接下来的循环 名称声明 便于接下来可以退出给循环
  loop---loop开始
      nCnt := nCnt - 1;
      record_StartNo := record_StartNo + 1;
      dbms_output.put_line(record_StartNo);
      if nCnt < 0 then ---判断  如果达到某一个条件 执行退出loop      
       exit looplabel; ---退出looplabel这个循环
      end if;---if语句必须要搭配使用
  end loop;---loop语句必须要搭配使用
  select max(nbbh) into maxnbbh from nmc3_record;---将test_recordd数据表中的nbbh最大值赋值给maxnbbh变量
  dbms_output.put_line(maxnbbh);
end;---begin语句必须要搭配使用

在plsql中打开程序块执行界面

参考:https://www.zhihu.com/column/c_1502301818272718849

pl/sql中变量的声明与使用:

参考https://zhuanlan.zhihu.com/p/507408401

PL/SQL 变量的声明和初始化

变量需要声明,初始化则可以在声明时进⾏,也可以不在此时进⾏,但是如果声明时定义为not null的情况下,就必须初始化才能使⽤。

变量声明的格式为:

复制代码
Identifier [CONSTANT]datatype [NOT NULL] [ := | DEFAULT expression ]

这⾥中括号中的内容都是可选项,具体含义如下:

  1. CONSTANT表⽰常量,⼀旦定义为常量,则不能在为该变量赋其他的值了;
  2. 如果定义了[NOT NULL],则该变量必须赋值
  3. PL/SQL中赋值使⽤的是 :=,初始化时也可以使⽤DEFAULT来定义默认值。
相关推荐
武子康6 分钟前
Java-07 深入浅出 MyBatis数据库一对多关系模型实战:表结构设计与查询实现
java·后端
字节跳动开源2 小时前
Viking AI 搜索 CLI 正式发布:会说话,就能做搜索推荐
数据库·人工智能·开源
REDcker2 小时前
Linux OverlayFS详解
java·linux·运维
Royzst2 小时前
xml知识点
java·服务器·前端
TechWJ3 小时前
数据库在公司内网,出差路上想查数据怎么办?
服务器·数据库·mariadb
我是一颗柠檬3 小时前
【MySQL全面教学】MySQL事务与ACID Day9(2026年)
数据库·后端·mysql
橙子圆1233 小时前
Redis知识9之集群
数据库·redis·缓存
鱼鳞_3 小时前
苍穹外卖-Day08(缓存套餐)
java·redis·缓存
BlackHeart12033 小时前
【SQL】Oracle中序列(Sequence)作为默认值引发的ORA-00979
数据库·sql·oracle
过期动态3 小时前
【LeetCode 热题 100】移动零
java·数据结构·算法·leetcode·职场和发展·rabbitmq