[解決済み] SQLテーブルのレコードをコピーして、新しい行のユニークIDを交換するにはどうすればよいですか?
2022-05-18 05:11:29
質問
この質問 は私が必要とするものに近いですが、私のシナリオは少し異なっています。ソーステーブルと宛先テーブルは同じで、プライマリキーはuniqueidentifier(guid)です。私がこれを試みるとき。
insert into MyTable
select * from MyTable where uniqueId = @Id;
主キーをコピーしようとしているため、明らかに主キー制約違反が発生します。実際、私は主キーをコピーしたいわけではありません。むしろ、新しいキーを作成したいのです。さらに、特定のフィールドを選択的にコピーし、他のフィールドはNULLのままにしておきたいと考えています。さらに複雑なことに、私は元のレコードの主キーを取り、それをコピーの別のフィールド (PreviousId フィールド) に挿入する必要があります。
私はこれに対する簡単なソリューションがあることを確信していますが、それが何であるかを知るために十分な TSQL を知らないだけです。
どのように解決するのですか?
これを試してみてください。
insert into MyTable(field1, field2, id_backup)
select field1, field2, uniqueId from MyTable where uniqueId = @Id;
指定されていないフィールドは、そのデフォルト値(定義されていない場合は通常NULL)を受け取る必要があります。
関連
-
[解決済み] SQL Server : 列を行に変換する
-
[解決済み] MySQLでコマンドラインを使用してSQLファイルをインポートするにはどうすればよいですか?
-
[解決済み] SQL Server テーブルにカラムが存在するかどうかを確認する方法は?
-
[解決済み] SQL Server の DateTime データ型から日付だけを返す方法
-
[解決済み] SQL Serverでテーブルからカラム名を取得するにはどうすればよいですか?
-
[解決済み] SQL Serverで、指定したテーブルを参照しているすべての外部キーを一覧表示するにはどうすればよいですか?
-
[解決済み] SQL Serverのトランザクションログをクリアするにはどうすればよいですか?
-
[解決済み] SQL Serverには、.NETのMath.Maxのような2つの値を取るMax関数はありますか?
-
[解決済み] "ON UPDATE CASCADE "を使用する場合について
-
[解決済み] SQL Management Studioで別のポート番号を指定するにはどうすればよいですか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
SQL-初心者のためのベスト入門SQLクエリ I
-
[解決済み] 各GROUP BYグループの最初の行を選択しますか?
-
[解決済み] SQLのSELECTでIF...THENを実行するにはどうすればよいですか?
-
[解決済み] テーブルネーミングのジレンマ:単数形と複数形の名前【非公開
-
[解決済み] ATTACHで開いたSQLiteデータベースファイルのテーブルを一覧表示するにはどうすればよいですか?
-
[解決済み] INNER JOINよりもCROSS APPLYを使用すべきなのはどのような場合ですか?
-
[解決済み] SQL JOIN - WHERE句とON句の比較
-
[解決済み] MySQLでFULL OUTER JOINを行うにはどうすればよいですか?
-
[解決済み] 各グループの上位1行を取得
-
[解決済み] ある列の最大値を持つ行を取得する