資料庫中的move操作

來源:互聯網
上載者:User

本文的幾個內容是一直就有點迷糊的,今天清理了一遍,記錄備忘.

在我們的系統中,有大量這樣的需求:把表goods中的資料,move到表spec_goods中.
(兩個表的列是相同的).一般來說,我們知道,最標準的寫法是這樣的:
insert into spec_goods(c1,c2,c3)  select c1,c2,c3 from goods where c3='A';

但我們系統中,這樣的表很多,每個表的列也很多,基本全部都有這樣的需求,按這樣的方法去寫,什麼時候是個盡頭?

所以想起了本科的資料庫教材,王姍編的那本綠皮書上說過select into的文法,所以試了
select into spec_goods from  goods where c3='A';
結果有兩種:
1)sybase上,該語句會建立表spec_goods,如果該表已經存在,則報錯
2)oracle上,該語句報文法錯

那就考慮另外的辦法吧,經過江南白衣的提示,有下面的語句可以實現同樣的功能:
insert into spec_goods  select * from goods where c3='A';
這條語句有特殊要求:
要求表spec_goods和表goods在建表時列都順序完全相同.

在sybase中,還有一種簡化的辦法:
insert into spec_goods(c1,c2,c3) from goods where c3='A';
這個文法在其它資料庫中不一定能行,oracle就不可以.

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.