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来定义默认值。
相关推荐
朦胧之3 小时前
AI 编程-老项目改造篇
java·前端·后端
程序猿大帅8 小时前
别再只当调包侠了:用 Spring AI 落地 Function Calling,我被大模型硬生生砸出了三个大坑
java
程序员晓琪9 小时前
约定大于配置:基于 Java 包名自动生成 API 版本路由的最佳实践
java·spring boot·后端
Flittly9 小时前
【AgentScope Java新手村系列】(11)中断与恢复
java·spring boot·spring
众少成多积小致巨9 小时前
JNI (Java Native Interface) 技术手册中文参考指南
android·java·c++
东坡白菜10 小时前
破局全栈:前端开发的Java入门实战记录—JPA(2)
java·后端
SimonKing16 小时前
艹,维护AI写的代码,我心态崩了......
java·后端·程序员
用户2986985301416 小时前
Java Word 文档样式进阶:段落与文本背景色设置完全指南
java·后端
倔强的石头_18 小时前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
小bo波1 天前
从"任意文件复制"深挖Java I/O:字符流与字节流的本质抉择
java·nio·io流·后端开发·文件复制