oracle 字符串賦值需要注意:
成都創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司一直秉承“誠(chéng)信做人,踏實(shí)做事”的原則,不欺瞞客戶,是我們最起碼的底線! 以服務(wù)為基礎(chǔ),以質(zhì)量求生存,以技術(shù)求發(fā)展,成交一個(gè)客戶多一個(gè)朋友!專注中小微企業(yè)官網(wǎng)定制,成都做網(wǎng)站、成都網(wǎng)站設(shè)計(jì),塑造企業(yè)網(wǎng)絡(luò)形象打造互聯(lián)網(wǎng)企業(yè)效應(yīng)。
1、定義變量(了解數(shù)據(jù)類型)
2、保存一個(gè)值=簡(jiǎn)單變量;保存多個(gè)值=復(fù)合變量
3、簡(jiǎn)單變量類型:char,varchar2,number,date(同時(shí)也列類型),boolean,表.字段%type
--復(fù)合變量:表%rowtype,record
DECLARE
v_empno NUMBER(4);
v_ename VARCHAR2(10);
v_job emp.job%TYPE; --如果字段類型改變,腳本不需要改變
BEGIN
v_empno := 7566;
SELECT ename,job INTO v_ename,v_job FROM emp WHERE empno=v_empno;
dbms_output.put_line(v_ename);
IF(v_job='MANAGER')THEN
dbms_output.put_line('經(jīng)理,吃過(guò)飯沒(méi)。');
END IF;
END;
1、創(chuàng)建測(cè)試表,
create table test_val(id varchar2(20),remark varchar2(20));
2、插入測(cè)試數(shù)據(jù);
insert into test_val select level, 'lvl_'||level remark from dual connect by level=100;
commit;
3、編寫語(yǔ)句,將表中的記錄數(shù)賦值給變量;
declare
v_int number;
begin
execute immediate 'select count(*) from test_val' into v_int;
end;
4、將變量值打印,查看結(jié)果;
dbms_output.put_line(v_int);
oracle賦值語(yǔ)句如下:
declare
bb table1.a%rowtype;
begin
select a into bb from table1 where b='1';
--dbms_output.put_line(bb);
賦值語(yǔ)句用來(lái)表明賦給某一個(gè)變量一個(gè)具體的確定值的語(yǔ)句叫做賦值語(yǔ)句。在算法語(yǔ)句中,賦值語(yǔ)句是最基本的語(yǔ)句。賦值運(yùn)算符左側(cè)的編程元素必須能夠接受和存儲(chǔ)值。這意味著編程元素必須是一個(gè)不為ReadOnly(VisualBasic)的變量或?qū)傩?,或者必須是一個(gè)數(shù)組元素。在賦值語(yǔ)句的上下文中,此類元素有時(shí)稱為lvalue,即“l(fā)eftvalue”(左側(cè)的值)。
如果存儲(chǔ)過(guò)程的名字是issuccess
可以這樣定義入?yún)?/p>
issuccess(PRM_I
in
varchar2).
調(diào)用的時(shí)候就可以:
issuccess('123456789');
作為傳入的值來(lái)處理。
如果需要把存儲(chǔ)過(guò)程中處理的結(jié)果返回出來(lái),那么可以定以O(shè)UT
參數(shù):
issuccess(PRM_I
in
varchar2,PRM_O
OUT
VARCHAR).
調(diào)用之前準(zhǔn)備一個(gè)變量
VS_OUT
varchar2(20);
調(diào)用時(shí):
issuccess('123456789',VS_OUT).
過(guò)程里面修改PRM_O的值,過(guò)程執(zhí)行完成后可以通過(guò)VS_OUT捕獲。