1、采用insert into values 語句插入一條,寫很多條語句即可多條數(shù)據(jù),這種主要針對于離散值以及一些基礎(chǔ)信息的錄入,如:insert into test(xh,mc) values('123','測試');
站在用戶的角度思考問題,與客戶深入溝通,找到東源網(wǎng)站設(shè)計與東源網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:做網(wǎng)站、成都網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣、域名注冊、網(wǎng)站空間、企業(yè)郵箱。業(yè)務(wù)覆蓋東源地區(qū)。
如果插入的數(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ù)拷貝進入。
打開行級鎖方法:
select t.*,rowid from 表名 t where 1=2;
select * from 表名 where 1=2 for update;
直接把excel數(shù)據(jù)拷貝到表里
你這樣 如果要插入的字符串中有單引號, 那么就需要skip掉。
先用個簡單的例子, 比如你要顯示 I'm 27 years old 作為字符串。
那么:
select 'I''m 27 yrs old' from dual; -- 這里看好: 最外層2個 單引號是說明后面是字符串。
里面的內(nèi)容變成了 I''m ..... 用了2個單引號。 第一個是表示“跳過”, 而不作為整個字符串的結(jié)尾。 第二個是真的內(nèi)容。
所以, 你如果要插入以上的SQL整個句子作為字符串,
那么就:
insert into tableT (testcolumn)
values (' select * from abc where a=''ab'' and b=''aa'' and c=''aa''');
每個單引號前面加上一個單引號“跳過” 而不進行字符串結(jié)尾處理。
insert?into?tonglu.tb_putoutconfirm(transfer_type,package_num,handledby,username,tms_service_code,batch,weight)values(?,?,?,?,?,tonglu.batch_seq.nextval,?);
按位置對應(yīng)一下,batch在段在倒數(shù)第二位,所以那個地方直接引用序列
其他你該怎么傳參數(shù)還怎么傳參數(shù)
工具/材料:電腦,oracle數(shù)據(jù)庫表
1.例test表中有如下數(shù)據(jù)。
2.插入一條id為6,name為楊七的數(shù)據(jù)。insert into testvalues (6,'楊七');commit。
3.向表中復(fù)制一條目前表中id為1的數(shù)據(jù),可用如下語句:insert into test select * from test where id=1;commit;在執(zhí)行insert語句后,必須提交,即commit,否則不成功。
我們在SQL*PLUS下執(zhí)行 SQL show all命令時,可以發(fā)現(xiàn)一個參數(shù):define (hex 26),如下所示 concat . (hex 2e) copycommit 0 copytypecheck ON define (hex 26) describe DEPTH 1 LINENUM OFF INDENT OFFecho OFF 這個是Oracle里面用來識別自定義變量的設(shè)置,現(xiàn)在我們在SQL*PLUS下將其關(guān)閉: SQL Set define OFF; 然后再次執(zhí)行導(dǎo)入腳本,OK!問題搞定。 注意:如果是在TOAD中執(zhí)行,建議在每一個要導(dǎo)入的腳本第一行加上前面那句關(guān)閉define的話,否則當(dāng)你導(dǎo)入第二個含有特殊字符的腳本的時候,又會出錯。 如果是在SQL*PLUS中執(zhí)行,則只需要設(shè)置一次define OFF,后面就可以連續(xù)導(dǎo)入了。直到你重新設(shè)置define ON為止。 ·方法二:在SQL語句中將''替換成chr(38),因為chr(38)是‘’的ASCII碼 SQL Select 'Tom' || chr(38) || 'Jerry' from dual; ·方法三:分拆原來的字符串 SQL Select 'Tom' || '' || 'Jerry' from dual; 我們可以看到,方法一最為簡便,而且效率也最高。方法二因為有一個調(diào)用函數(shù)的過程,所以性能稍差。方法三需要兩次連接字符串,效率最差! ·方法一:使用轉(zhuǎn)義字符 SQL Select 'test' || '''' from dual; 第三個'才是我們真正的內(nèi)容 ·方法二:同樣是使用轉(zhuǎn)義字符,只不過方式不同而已 SQL Select 'test ''' from dual; 注意:這里的第二個,第三個'就是我們上面方法一中提到的轉(zhuǎn)義符和真正的內(nèi)容
首先要理解一下PreparedStatement,是具有預(yù)編譯功能的,也就是說他會先編譯成一個固定的格式,然后后面設(shè)置的就不需要再一次編譯,節(jié)省了編譯過程,建議看一下PreparedStatement
這個類的詳細說明。
你這個sql明顯是錯的。
String rsIns = "insert into test values (id)";
這個建議把sql寫完整,這樣就不會亂,也不會錯。
比如只想插入id那么要把id聲明一下,如果不寫那就默認要插入所有的字段,你這里就沒有生命,然后只插入id,肯定是錯的。
正確寫法一
String rsIns = "insert into test(id) values (“+id+”)";
try {
PreparedStatement p = conn.prepareStatement(rsIns);
p.excuteUpdate(rsIns);
} catch (Exception e) {
// TODO: handle exception
/ 釋放資源操作
};
寫法二
String rsIns = "insert into test(id) values (?)";
try {
PreparedStatement p = conn.prepareStatement(rsIns);
p.setInt(1, id);
p.excuteUpdate(rsIns);
} catch (Exception e) {
// TODO: handle exception
// 釋放資源操作
};
PS:
setInt和setString方法里邊的參數(shù)具體都是什么意思?
這里只有第二中需要setInt或者setXXX操作。具體的意思就是比如
p.setInt(1, id);
第一個參數(shù)是順序號,也就是第幾個問號。這里的sql
String rsIns = "insert into test(id) values (?)";
只有一個問號,那么序號就是1,第二個參數(shù)就是這個問號的值,比如這個sql中的問號其實就是要傳的id
又比如String sql = "insert into user(id, name) values (?,?)";
這里要設(shè)置的話
第一個問號代表的是id,而且是int類型的那么就有
p.setInt(1,id);
第二個問號代表的是name,而且是String類型的那么就有
p.setString(2,name);
不知道這么說明白了么?不明白可以再問。