存儲過程使用變數
一、變數的定義
mysql中變數定義用declare來定義一局部變數,該變數的使用范圍只能在begin...end
塊中使用,變數必須定義在復合語句的開頭,並且是在其它語句之前,也可以同時申明多個變數,如果需要,可以使用default賦默認值。
定義一個變數語法如下:
declare
var_name[,...]
type[default
value]看一個變數定義實例
declare
last
date;二、mysql存儲過程變數賦值
變數的賦值可直接賦值與查詢賦值來操作,直接賦值可以用set來操作,可以是常量或表達式如果下
復制代碼
代碼如下:
set
var_name=
[,var_name
expr]...給上面的last變數賦值方法如下
set
last
=
date_sub(
current_date(),interval
1
month);下面看通過查詢給變數賦值,要求查詢返回的結果必須為一行,具體操作如下
select
col
into
var_name[,...]
table_expr我們來通過查詢給v_pay賦值。
create
function
get
_cost(p_custid
int,p_eff
datetime)
return
decimal(5,2)
deterministic
reads
sql
data
begin
declare
v_pay
decimail(5,2);
select
ifnull(
sum(pay.amount),0)
into
vpay
from
payment
where
pay.payd<=p_eff
and
pay.custid=pid
reutrn
v_rent
+
v_over
-
v_pay;
end
$$
好了,這篇簡單的存儲過程中變數的定義賦值教程就到這里了,下面我們會接著講關於myql存儲過程的條件的定義與處理。
以下是其它網友的補充
在MySQL的存儲過程中,可以使用變數,它用於保存處理過程中的值。
定義變數使用DECLARE語句,語法格式如下:
DECLARE
var_name[,...]
type
[DEFAULT
value]
其中,var_name為變數名稱,type為MySQL支持的任何數據類型,可選項[DEFAULT
value]為變數指定默認值。一次可以定義多個同類型的變數,各變數名稱之間以逗號「,」隔開。
定義與使用變數時需要注意以下幾點:
◆
DECLARE語句必須用在DEGIN…END語句塊中,並且必須出現在DEGIN…END語句塊的最前面,即出現在其他語句之前。
◆
DECLARE定義的變數的作用范圍僅限於DECLARE語句所在的DEGIN…END塊內及嵌套在該塊內的其他DEGIN…END塊。
◆
存儲過程中的變數名不區分大小寫。
定義後的變數採用SET語句進行賦值,語法格式如下:
SET
var_name
=
expr
[,var_name
=
expr]
...
其中,var_name為變數名,expr為值或者返回值的表達式,可以使任何MySQL支持的返回值的表達式。一次可以為多個變數賦值,多個「變數名=值」對之間以逗號「,」隔開。
例如:
復制代碼
代碼如下:
begin
declare
no
varchar(20);
declare
title
varchar(30);
set
no='101010',title='存儲過程中定義變數與賦值';
end
提示:存儲過程中所有的關鍵字也是不區分大小寫的,如BEGIN可以寫出begin。
② Mysql將存儲過程執行後的值賦值給變數
Mysql存儲過程查詢結果賦值到變數的方法
把查詢結果賦值到變數,大部分情況下使用游標來完成,但是如果明確知道查詢結果只有一行(例如統計記錄的數量,某個欄位求和等),其實可以使用set或into的方式來實現賦值。示例代碼:
drop table if exists test_tbl;
create table test_tbl (name varchar(20), status int(2));
insert into test_tbl values('abc', 1),('edf', 2),('xyz', 3);
drop procere IF EXISTS pro_test_3;
delimiter //
create procere pro_test_3()
begin
DECLARE cnt INT DEFAULT 0;
select count(*) into cnt from test_tbl;
select cnt;
-- 多個列的情況下似乎只能用 into 方式
select max(status), avg(status) into @max, @avg from test_tbl;
select @max, @avg;
end
delimiter ;
call pro_test_3();
③ 存儲過程中日期的變數是什麼
DATE。存儲過程引導數據時,通常使用時間欄位(時間戳)洞掘來確定是否需要更新,存儲洞慧過程中的變數定義為DATE,則Oracle會根據變數DATE自動將數據表中的時間欄位轉換為日期類型,並截取時間信息,但是,要導入的數據一天要更新多納顫答次,並且實時性要求較高,因此必須精確到秒。從變數的作用域(即從空間)的角度來觀察,變數可以分為全局變數和局部變數。變數的存儲有兩種不同的方式:靜態存儲方式和動態存儲方式。
④ oracle存儲過程中如何對一個變數累加賦值 最好有個例子
1、首先打開oracle資料庫,如下圖所示。
⑤ 存儲過程中如何定義一個變數
存儲過程常見的變數:局部變數、用戶變數、系統變數
⑥ oracle的存儲過程里怎樣調用動態變數
實現思路:
第一步:先定義一個字元串,這個字元串SQL是由動態變數和其他的sql語句成分拼接組成。
第二步:直接執行execute immediate SQL;
備註:以上方法是oracle提供的動態執行方法語句,直接使用就可以。
VAR_DYNAMIC_SQL:='INSERTINTORP_COMFIRMED_EVENT_DETAIL(
EVENT_ID,--ID
TRANS_TIME,--交易時間
TRANS_TYPE,--交易類型
TRANS_PROVINCE,--開戶省份
CCE_CSTNO,--客戶號
CCE_CERTTYPE,--證件類型
CCE_CERTNO,--證件號
CCE_AMT,--交易金額
CCE_RISK_SCORE,--不處理的風險分值
CCE_PAYEE_ACC,--付款人賬號
CCE_PAYEE_NAME,--付款人姓名
CCE_REC_NODE,--收款人開戶行
CCE_REC_ACC,--收款人賬號
CCE_REC_NAME,--收款人姓名
RULE_NAME,--規則名稱
CCE_RULE_NOTE,--規則描述
SCORE_RANGE--處理後的風險分值
)select
EVENT_ID,
SYS_CREATION_DATE,
GET_NAME_BY_CODE(GET_TOTAL_EVENT_TYPE(T1.EVENT_TYPE,T1.USER_DEFINED_EVENT_TYPE),''eventType'')ASTRANS_TYPE,
--get_province(IP_COUNTRY,IP_CITY)ASCCE_TRANSTYPE,
get_vale_from_cd_p('||get_vale_from_cd1('13','5')||'),--開戶省份為自定義欄位
USER_ID,
'||get_vale_from_cd1('4','4')||',--證件類型為自定義欄位
'||get_vale_from_cd1('7','4')||',--證件號為自定義欄位要轉換成動態SQL
GET_AMT_BY_CURRENCY(AMOUNT_ORIGINAL,AMOUNT_CURRENCY),--通過匯率和幣種轉換
RISK_SCORE,
USER_ACCT_NUMBER,
'||get_vale_from_cd_g1(get_vale_from_cd_al)||',--付款人姓名
'||get_vale_from_cd1('11','5')||',--收款人開戶行自定義欄位需轉換成動態SQL
EXT_ACCT_NUMBER,
EXT_ACCT_OWNER_NAME,
NVL(POLICY_RULE_ID,''FALLBACK_RULE'')ASRULE_NAME,
SUBSTR(GET_RULE_ORDER_ID(ORG_ID,POLICY_RULE_ID),INSTR(GET_RULE_ORDER_ID(ORG_ID,POLICY_RULE_ID),''-'')+1),--描述
GET_SCORE_RANGE(RISK_SCORE)ASRISK_SCORE_RANGE
FROMEVENT_LOG_REALTIMET1
))';
executeimmediateVAR_DYNAMIC_SQL;
⑦ mysql存儲過程在游標中怎麼使用變數作為表明
(1)CONCAT()//字元連接
(2)CONCAT_WS()//使用指定的分隔符進行字元連接
(3)FORMAT()//數字格式化
(4)LOWER()//轉化小寫
(5)UPPER()//轉換大寫
(6)LEFT()//獲取左側字元
(7)RIGHT()//獲取右側字元
(8)LENGTH()//取得字元串長度
(9)LTRIM(),RTRIM(),TRIM()//刪除前導、後續空格或者指定字元
(10)REPLACE()//替換
(11)SUBSTRING()//字元串截取
(12)[NOT] LIKE//模式匹配——百分號%代表任意個字元;下劃線_代表任意一個字元
⑧ 存儲過程的變數指什麼
存儲過程是面向對象的資料庫編程語言,與其他面向對象編程語言類似,可聲明變數,用變數來存取某一類值,變數在存儲過程中佔有非常重要的位置。變數聲明在MySQL語言的存儲過程中,變數有會話變數、存儲過程變數兩種。兩種變數的聲明方式不同,作用場景也不盡相同,在實際使用中要根據需要加以選擇。
1.變數種類((1)會話變數會話變數也稱用戶變數,可以在一個客戶端會話的任何地方聲明,作用域是整個會話,會話斷開後,會話變數也就消失。會話變數名以@開頭,使用set直接賦值,在一個會話內,會話變數只需初始化一次。
例如,Set@num=1;表示聲明了一個名字叫「@num」的會話變數,其初始值為1。
(2)存儲過程變數存儲過程變數以DECLARE為關鍵字聲明的變數,只能在存儲過程中使用,其命名不需要以@開頭。以DECLARE聲明的變數都會被初始化為NULL,存儲過程變數存在於資料庫伺服器上。2.變數定義存儲過程變數定義格式:DECLARE+變數名+數據類型+[DEFAULTVALUE]其中,((1)DECLARE為聲明存儲過程變數的關鍵字;
(2)變數名可以任意,但盡可能達到能表意的目的;
(3)數據類型為MySQL的數據類型,如int
⑨ Oracle存儲過程where語句使用變數
create PROCEDURE p_update
(V_DQDM in varchar2(6))
as
begin
if length(V_DQDM)=6
then
update table1 ..... where dqdm=V_DQDM;
commit;
else
update table1 ..... where dqdm like V_DQDM||'%'
commit;
end if;
end p_update;
類似這么寫