[解決済み] MS SQL Server Management Studio でトランザクションを処理する最適な方法
2022-07-09 13:02:49
質問
構文的にも意味的にも正しいSQL文があり、それが実行されるとします。
Management Studio (または他のクエリツール) では、どのように SQL 文をテストし、何かを壊したことに気づいたら、ロールバック (別のクエリで?) することができますか?
どのように解決するのですか?
最も簡単な方法は、コードをトランザクションでラップし、T-SQL コードの各バッチを 1 行ずつ実行することです。
例えば
Begin Transaction
-Do some T-SQL queries here.
Rollback transaction -- OR commit transaction
エラー処理を組み込みたい場合は、TRY...CATCH BLOCKを使用することで実現できます。エラーが発生した場合は、キャッチブロックの中でトランザクションをロールバックすることができます。
例えば
USE AdventureWorks;
GO
BEGIN TRANSACTION;
BEGIN TRY
-- Generate a constraint violation error.
DELETE FROM Production.Product
WHERE ProductID = 980;
END TRY
BEGIN CATCH
SELECT
ERROR_NUMBER() AS ErrorNumber
,ERROR_SEVERITY() AS ErrorSeverity
,ERROR_STATE() AS ErrorState
,ERROR_PROCEDURE() AS ErrorProcedure
,ERROR_LINE() AS ErrorLine
,ERROR_MESSAGE() AS ErrorMessage;
IF @@TRANCOUNT > 0
ROLLBACK TRANSACTION;
END CATCH;
IF @@TRANCOUNT > 0
COMMIT TRANSACTION;
GO
詳しくは以下のリンクをご覧ください。
http://msdn.microsoft.com/en-us/library/ms175976.aspx
これがお役に立てれば幸いですが、もっと詳細が必要な場合はお知らせください。
関連
-
executeQuery()ソリューションでデータ操作文を発行できない。
-
[解決済み] SQL ServerでSELECTからUPDATEする方法とは?
-
[解決済み] SQL Server で複数行のテキストを 1 つのテキスト文字列に連結する方法
-
[解決済み] SQL Server テーブルにカラムが存在するかどうかを確認する方法は?
-
[解決済み] SQL Server の DateTime データ型から日付だけを返す方法
-
[解決済み] SQL ServerにおけるLEFT JOINとLEFT OUTER JOINの比較
-
[解決済み] SQL ServerでJOINを使用してUPDATE文を実行するにはどうすればよいですか?
-
[解決済み] SQL Server - 挿入された行のIDを取得するための最良の方法は?
-
[解決済み】SQL Serverで既存のテーブルにデフォルト値を持つカラムを追加する
-
[解決済み】SQL Server SELECT INTO @variable?
最新
-
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 実装 サイバーパンク風ボタン
おすすめ
-
[エラー処理] [MySQL] [Err] 1241 - オペランドは 1 つのカラムを含む必要があります。
-
[解決済み] アドホッククエリとは何ですか?
-
[解決済み] SQLのSELECTでIF...THENを実行するにはどうすればよいですか?
-
[解決済み] UNIONとUNION ALLの違いは何ですか?
-
[解決済み] ATTACHで開いたSQLiteデータベースファイルのテーブルを一覧表示するにはどうすればよいですか?
-
[解決済み] INNER JOIN ON vs WHERE句
-
[解決済み] SQL Server の VARCHAR/NVARCHAR 文字列に改行を挿入する方法
-
[解決済み] 文字列の一部をUPDATEおよびREPLACEする。
-
[解決済み] SQLサーバーで行を列に効率的に変換する
-
[解決済み] Postgres でサブクエリを使用してテーブルの行を更新する