沒看明白具體問題是什么?
我們一直強(qiáng)調(diào)網(wǎng)站設(shè)計、成都做網(wǎng)站對于企業(yè)的重要性,如果您也覺得重要,那么就需要我們慎重對待,選擇一個安全靠譜的網(wǎng)站建設(shè)公司,企業(yè)網(wǎng)站我們建議是要么不做,要么就做好,讓網(wǎng)站能真正成為企業(yè)發(fā)展過程中的有力推手。專業(yè)的建站公司不一定是大公司,創(chuàng)新互聯(lián)作為專業(yè)的網(wǎng)絡(luò)公司選擇我們就是放心。
是每隔一天就重新循環(huán) ,不想讓其循環(huán)還是想讓其循環(huán)?
不想讓其循環(huán)看看是不是序列的最大值設(shè)置的小了,到最大值后,序列會從最小值重新開始,或者是有固定的job設(shè)置了序列的值;
想讓其循環(huán),則可以創(chuàng)建一個job,在job里刪除序列重建即可。
要對表中的字段進(jìn)行遍歷嗎? 用user_tab_cols
begin
for i in (
select column_name from user_tab_cols where table_name=upper('表名'))
loop
dbms_output.put_line(i.column_name);
end loop;
end;
使用loop循環(huán),比如:
for item in (select a,b,c from table_a where 條件) loop
insert into table_b(a,b,c) values (item.a,item.b,item.c);
end loop;
也可以使用索引表循環(huán),以上只是一個簡單的例子,需要根據(jù)你的具體情況選擇循環(huán)方式。
1、采用insert into values 語句插入一條,寫很多條語句即可多條數(shù)據(jù),這種主要針對于離散值以及一些基礎(chǔ)信息的錄入,如:insert into test(xh,mc) values('123','測試');
如果插入的數(shù)據(jù)有規(guī)律,可利用for、loop循環(huán)插入,主要用于批量生成測試數(shù)據(jù)
begin
for i in 1 .. 100 loop
insert into test(xh,mc) values(i||'','測試');
end loop;
end ;。
2、采用insert into selct from 語句來一次性插入一個集合,這種主要依據(jù)于要插入的數(shù)據(jù)源已經(jīng)存儲于數(shù)據(jù)庫對象中,或者利用dual虛表來構(gòu)造數(shù)據(jù),經(jīng)過加工后寫入一個集合。
insert into test (xh,mx) select '123','測試' from dual;
3、采用plsql等工具、或者oracle的imp、impdp命令來導(dǎo)入,這種主要用數(shù)據(jù)庫與數(shù)據(jù)庫之間的大批量數(shù)據(jù)導(dǎo)入,導(dǎo)入的數(shù)據(jù)格式為plsql的pde、oracle的dmp等。dmp文件可使用
table_exists_action參數(shù)控制導(dǎo)入動作:replace替換原表,truncate清除原表數(shù)據(jù)再導(dǎo)入,append增量導(dǎo)入數(shù)據(jù),當(dāng)然impdp數(shù)據(jù)泵的導(dǎo)入要依賴于directory路徑。
impdp 用戶名/密碼 dumpfile=123.dmp logfile=123.log directory=imp_dir tables=test table_exists_action=append。
4、使用excel文件直接拷貝。這種主要用于要寫入的數(shù)據(jù)已是excel文件或者行列分明的其它格式文件,每一列的值和表結(jié)構(gòu)相對應(yīng),可直接打開表的行級鎖,把數(shù)據(jù)拷貝進(jìn)入。
--1.For
FOR?循環(huán)變量?IN?[REVERSE]?下界..上界
LOOP
語句組
END?LOOP;
--計算5的階乘,并在屏幕上打印出來。
DECLARE
num?NUMBER(3):=5;
resu?NUMBER(3):=1;
BEGIN
for?i?in?1..num?loop
resu:=?resu?*?i;
end?loop;
dbms_output.put_line(TO_CHAR(resu));
END;
--2.WHILE循環(huán)
語法格式:
WHILE?條件?LOOP
語句組
END?LOOP;
--用WHILE循環(huán)求1~100所有整數(shù)的和?
DECLARE
summ?number?:=0;
i?number(3):=100;
BEGIN
WHILE?i0?LOOP
summ:=summ+i;
i:=i?-?1;
END?LOOP;
dbms_output.put_line(summ);
END;
哥們,不用循環(huán)吧?再說用循環(huán)也不能解決吧,循環(huán)你的值怎么賦?你怎么知道下個記錄該更新成什么?
通過to_char(to_date(logintime,'yy-mm-dd'),'yyyy-mm-dd')試試可不可轉(zhuǎn)換,沒環(huán)境沒法試,不行的話用instr函數(shù),一句update就行了,不過我現(xiàn)在沒時間寫代碼,給你個思路
instr((logintime,'-',1)可以取出第一個-的位置,然后通過substr(logintime,1,instr((logintime,'-',1)-1)取出第一個-前面的部分,就是年,20||就行了,然后再用instr(logintime,'-',2)
--這個是第2個-的位置,知道第1、2個-的位置后還是通過substr取出第1個-和第2個-之間的字符,就是月,case when一下如果是1位就補(bǔ)個0,。。。。依次類推,麻煩是麻煩點,但是比較通用,能適應(yīng)各種情況,不過日期的話應(yīng)該有規(guī)律,應(yīng)該能根據(jù)規(guī)律簡化不少,你自己琢磨吧.
如果你非要用循環(huán)可通過rowid這個偽列,即定義一個參數(shù)做計數(shù)用,循環(huán)一次加1,直到等于max(rowid)為止,不過我實在想不出用循環(huán)怎么弄,期待高手。。。
你這個其實挺復(fù)雜的,要建立一系列的東西來滿足你這個需求
給你做個實驗吧
先建立一個表
create?table?test
(id?varchar2(20)?not?null?primary?key?,
name?varchar2(100));
創(chuàng)建一個序列
create?sequence?seqTest?
increment?by?1?
start?with?1?
maxvalue?999
nocycle?
cache?10;
創(chuàng)建一個存儲過程,這個很重要,每天半夜12點執(zhí)行一次,這個主要是把序列重新置0用的,然后還需要定義一個job來調(diào)用這個存儲過程
create?or?replace?procedure?p_seq
as
n?number(10);
v_sql?varchar2(100);
begin
select?seqTest.nextval?into?n?from?dual;
n:=-(n-1);
v_sql:='alter?sequence?seqTest?increment?by'||?n;
execute?immediate?v_sql;
select?seqTest.nextval?into?n?from?dual;
v_sql:='alter?sequence?seqTest?increment?by?1';
execute?immediate?v_sql;
end;
然后創(chuàng)建一個觸發(fā)器
create?or?replace?trigger?t_test???????
before?insert?on?test???????
for?each?row???????
begin???????
select?to_char(sysdate,'yyyymmdd')||'_'||lpad(seqTest.nextval,3,0)?into?:new.id?from?dual;?????
end?;
存儲過程我沒測試,但是編譯能過去
現(xiàn)在做個試驗
執(zhí)行這樣一個語句
insert?into?test(name)?values?('aa');
然后你檢查下數(shù)據(jù),然后繼續(xù)插入再看看
select?*?from?test;
網(wǎng)站標(biāo)題:oracle如何循環(huán)列,oracle中循環(huán)如何使用
瀏覽地址:http://jinyejixie.com/article26/dssdjcg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)、網(wǎng)站設(shè)計公司、網(wǎng)頁設(shè)計公司、網(wǎng)站策劃、企業(yè)建站、Google
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)