存储过程中变量的定义

 

1.常用类型:
number  数字型(包括小数)    char(n)  varchar2(n)  字符型
boolean 布尔型
2.定义与表相关:
tableA.columnA%type;    字段类型相同
tableA%rowtype;

3.包头部分定义:
定义集合
TYPE dt_deduct_fund is RECORD(
    invest_id t_contract_invest.invest_id%TYPE,
    fund_type t_contract_invest.fund_type%type,
    fund_code t_fund.fund_code%TYPE,
    money_id t_money.money_id%TYPE); 
 
### 变量定义的时机 - **Oracle**:在Oracle的存储过程中,变量定义通常位于 `DECLARE` 部分,这是一个可选的部分,用于声明局部变量、游标、异常处理等。一旦进入 `BEGIN` 部分,就开始执行存储过程的主体逻辑,此时不能再定义新的变量。例如: ```plsql CREATE OR REPLACE PROCEDURE test_proc IS -- 变量定义在 DECLARE 部分 v_num NUMBER := 10; v_str VARCHAR2(100) := 'Hello'; BEGIN -- 存储过程主体逻辑 DBMS_OUTPUT.PUT_LINE(v_num); DBMS_OUTPUT.PUT_LINE(v_str); END; ``` - **MySQL**:在MySQL的存储过程中,变量定义通常在存储过程的开始部分,但不需要像Oracle那样有单独的 `DECLARE` 关键字块。变量定义必须在存储过程的主体逻辑之前,一旦开始执行主体逻辑,就不能再定义新的变量。例如: ```sql DELIMITER // CREATE PROCEDURE test_proc() BEGIN -- 变量定义存储过程开始部分 DECLARE v_num INT DEFAULT 10; DECLARE v_str VARCHAR(100) DEFAULT 'Hello'; -- 存储过程主体逻辑 SELECT v_num, v_str; END // DELIMITER ; ``` ### 变量定义的差异 - **语法差异**:Oracle使用 `DECLARE` 关键字来划分变量定义部分,而MySQL使用 `DECLARE` 关键字直接在存储过程主体内部定义变量,且不需要单独的 `DECLARE` 块。 - **数据类型差异**:Oracle和MySQL支持的数据类型有所不同。例如,Oracle有 `NUMBER`、`VARCHAR2` 等数据类型,而MySQL有 `INT`、`VARCHAR` 等数据类型。在定义变量时,需要根据数据库的不同选择合适的数据类型。 - **默认值设置差异**:在Oracle中,可以在变量定义时直接使用 `:=` 来设置默认值;而在MySQL中,使用 `DEFAULT` 关键字来设置默认值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值