這種過程想要看到輸出值一般來說是用dbms_output包中的put_line來做的,在serverout 開啟的情況下,這個(gè)會(huì)包中的函數(shù)會(huì)將查詢的結(jié)果什么的,直接打印在屏幕上。
為千山等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及千山網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為成都做網(wǎng)站、網(wǎng)站建設(shè)、千山網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!
其他時(shí)間的查詢結(jié)果只會(huì)在后臺(tái)作為了一個(gè)過程量存在(這里查詢語句中顯示的1,就是一個(gè)過程量,當(dāng)過程執(zhí)行完,或者這個(gè)1傳遞完,那么這個(gè)1也就消失了),除非你將查詢結(jié)果插入一張表內(nèi),這樣的話你就能看見存儲(chǔ)在那張插入表內(nèi)的結(jié)果了,一般來說過程中的量是不會(huì)直接輸出到屏幕上的。(如果是自定義函數(shù)有返回值,那么肯定是可以輸出到屏幕上的)
當(dāng)然還有一種情況能看到查詢結(jié)果,那就是調(diào)試,調(diào)試過程的時(shí)候(其實(shí)就是一步一步的執(zhí)行過程,有些工具是一行一行的),用工具能看到每一步的結(jié)果。
oracle記錄中選擇出第一條記錄的方法。
如下參考:
1.創(chuàng)建測試表
Createtabletest_order(idnumber,valuevarchar2(50));
2.插入測試數(shù)據(jù)
插入test_order值(3,'v3');
插入test_order值(2,'v2');
插入test_order值(1,'v1');
插入test_order值(5,'v5');
插入test_order值(4,'v4');
提交;
3.檢查查詢表中的全部數(shù)據(jù),可以發(fā)現(xiàn)數(shù)據(jù)沒有排序,選擇t。*,rowidfromtest_ordert;
4.寫SQL,數(shù)據(jù)只要第一個(gè)記錄(不是rownum=1)select*from(selectt)。*,row_number()/(orderbyid)rnfromtest_ordert)t,其中rn=1;
你可以在cmd底下試試exp指令。\x0d\x0aexp username/password@tnsname owner=要導(dǎo)出的用戶名 file=.....\x0d\x0aexp具體的參數(shù)你可以到網(wǎng)上詳細(xì)查一下。 \x0d\x0a\x0d\x0a基本語法和實(shí)例: \x0d\x0a 1、EXP: \x0d\x0a 有三種主要的方式(完全、用戶、表) \x0d\x0a 1、完全: \x0d\x0a EXP SYSTEM/MANAGER BUFFER=64000 FILE=C:\FULL.DMP FULL=Y \x0d\x0a 如果要執(zhí)行完全導(dǎo)出,必須具有特殊的權(quán)限 \x0d\x0a 2、用戶模式: \x0d\x0a EXP SONIC/SONIC BUFFER=64000 FILE=C:\SONIC.DMP OWNER=SONIC \x0d\x0a 這樣用戶SONIC的所有對(duì)象被輸出到文件中。 \x0d\x0a 3、表模式:\x0d\x0a EXP SONIC/SONIC BUFFER=64000 FILE=C:\SONIC.DMP OWNER=SONIC TABLES=(SONIC) \x0d\x0a 這樣用戶SONIC的表SONIC就被導(dǎo)出
declare
v_num number;
v_now number;
v_yes number;
c_max number;
begin
v_num:=1;
c_max:=200;--這里設(shè)置最大數(shù),想要100這內(nèi)就寫100,想要1000之內(nèi)就寫1000
loop
v_now:=2;--這里設(shè)置每一個(gè)數(shù)的初始被除數(shù),從2開始
v_yes:=1;--設(shè)置初始參考數(shù),1為素?cái)?shù),0為非素?cái)?shù),默認(rèn)初始為1
if v_num4 then
dbms_output.put_line(v_num);--1到3都是素?cái)?shù),這里就不再判斷了
-- v_num:=v_num+1;--自增1
end if;
if v_num=4 then
--這里開始判斷,只能被1和本身整除的數(shù),就是素?cái)?shù)
loop
if mod(v_num,v_now)=0 and v_numv_now then --如果有能被整除的數(shù),且被除數(shù)不是除數(shù)本身,就不是素?cái)?shù)
v_yes:=0;
end if;
v_now:=v_now+1;--被除數(shù)遞增
exit when v_now=v_num;--當(dāng)被除數(shù)大于除數(shù)時(shí)退出
end loop;--因?yàn)橐粋€(gè)一個(gè)的判斷,所以要來一次循環(huán)
end if;
if v_num4 and v_yes=1 then
dbms_output.put_line(v_num);
-- v_num:=v_num+1;--自增
end if;
v_num:=v_num+1;--自增
exit when v_num=c_max;
end loop;
end;
參考一下,自己寫的
可用DBMS_OUTPUT.PUT_LINE()對(duì)存儲(chǔ)過程的進(jìn)行輸出。
編寫存儲(chǔ)過程:
create or replace procedure test_pro(in_num number)
as
M number;
begin
M := in_num;
if 0 M then
dbms_output.put_line('輸出SQL語句1');
elsif M 3 then
dbms_output.put_line('輸出SQL語句2');
else
dbms_output.put_line('nothing');
end if;
end;
擴(kuò)展資料;
存儲(chǔ)在數(shù)據(jù)庫的數(shù)據(jù)字典中,存儲(chǔ)在當(dāng)前的應(yīng)用中安全性由數(shù)據(jù)庫提供安全保證,必須通過授權(quán)才能使用存儲(chǔ)子程序,安全性靠應(yīng)用程序來保證,如果能執(zhí)行應(yīng)用程序,就能執(zhí)行該子程序。模式描述IN參數(shù)用來從調(diào)用環(huán)境中向存儲(chǔ)過程傳遞值,不能給IN參數(shù)賦值,給此參數(shù)傳遞的值可以是常量、有值的變量、表達(dá)式等。
參考資料來源:百度百科-Oracle存儲(chǔ)過程
create table student (id number(2),name varchar2(20));
insert into student values (1,'A,B,C');
insert into student values (2,'D,E');
commit;
select distinct id, regexp_substr(name, '[^,]+', 1, level) name
from student
connect by level = length(name) - length(replace(name, ',')) + 1 order by id,name;