DB SQL SQLServer

[SQL Server]テーブルを丸ごとコピーするSQL

SQL Serverでは、SELECT * INTOステートメントを使用することで、既存のテーブルから新しいテーブルを作成し、そのデータをコピーすることができます。

データのバックアップなど、既存のテーブルと同じテーブル構成ででたを保持しておきたい時用のSQLです。

## origin_tableにコピー元となるテーブルをしてする
## new_tableに新しいテーブル名を記述する
SELECT * INTO new_table FROM origin_table;

 

基本的にはSELECT文なのでwhere句を指定できます。

これを利用して、SELECT * INTOステートメントでデータ不要でテーブルのみコピーする方法は以下となります。

## SELECT * INTO 新しいテーブル FROM 既存のテーブル WHERE 1=0;
SELECT * INTO new_table FROM origin_table WHERE 1=0;

 

  • この記事を書いた人

朝倉卍丸

シングルモルトスコッチなどのお土産を持ってきた人を助けるのが好きです。サービスの分割が重要ですが、まあ昔ながらの方法でやりたいこともありますよね。

よく読まれている記事

条件の0=0は全てが正であるを意味するSQL 1

SQLの条件に0=0のような記述を見かけます。 変わった書き方の条件ですが、これは「全てが正である」事を意味しており、結合条件の場合はCROSS JOINと同じです。 下記の例で言えば、結合するsub ...

DISTINCTを使わないで重複排除を考えるSQL 2

SQLのDISTINCTはEXISTSとかGROUP BYでなんとかする事もできます。 DISTINCTは暗黙的なソートがされますが、何のDBを使うにせよ過去のバージョンならともかく、最近のバージョン ...

RFC 5322に準拠させた正規表現言語別 3

RFC5322で定義されている正規表現を、各言語の正規表現に変化させた形になります。 完全な電子メール正規表現は存在しないので、結局のところ何かの公式基準に従っていたとしても、自分が携わるサービスのル ...

-DB, SQL, SQLServer