SQL Serverのトリガーでは、Oracleのような「BEFORE INSERT ON」と言った、テーブル操作前に動作するトリガーコマンドは存在しません。
SQL Serverではテーブル操作前に動作するトリガーは存在しない
まあ、マイクロソフトの公式のドキュメント見て貰えば分かる話ですが、トリガーにいくつか種類が存在しても、実態としてはアフタートリガー(After Trigger)しか存在していません。あくまでも、DML(INSERT・DELETE・UPDATE)が実行された後にトリガーが発動するため、トリガーは実行結果データに対する操作となります。
なので、QiitaでもSQL Server用のトリガーを自作している方もいらっしゃいます。
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fcdn.qiita.com%2Fassets%2Fpublic%2Farticle-ogp-background-9f5428127621718a910c8b63951390ad.png?ixlib=rb-4.0.0&w=1200&mark64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTkxNiZoPTMzNiZ0eHQ9U1FMU2VydmVyJUUzJTgxJUFFJUUzJTgzJTg4JUUzJTgzJUFBJUUzJTgyJUFDJUUzJTgzJUJDJUUzJTgxJUE3T3JhY2xlJUUzJTgxJUFFQmVmb3JlJUUzJTgyJTkyJUU3JTk2JTkxJUU0JUJDJUJDJUU3JTlBJTg0JUUzJTgxJUFCJUU1JTg2JThEJUU3JThGJUJFJUUzJTgxJTk5JUUzJTgyJThCJnR4dC1jb2xvcj0lMjMyMTIxMjEmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9NTYmdHh0LWNsaXA9ZWxsaXBzaXMmdHh0LWFsaWduPWxlZnQlMkN0b3Amcz0xNTI0ZTRmOTU3OGRlNDM4Njg2M2ZkM2U2NzRjZWE1Ng&mark-x=142&mark-y=112&blend64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTYxNiZ0eHQ9JTQwc29fbmtieXMmdHh0LWNvbG9yPSUyMzIxMjEyMSZ0eHQtZm9udD1IaXJhZ2lubyUyMFNhbnMlMjBXNiZ0eHQtc2l6ZT0zNiZ0eHQtYWxpZ249bGVmdCUyQ3RvcCZzPTIyNWZkNTFlMzMxYzQzMjg4MTFkMWY2ZGQwZTBiYjIx&blend-x=142&blend-y=491&blend-mode=normal&s=f5ca2234d0f66589835d557b70418e18)
SQLServerのトリガーでOracleのBeforeを疑似的に再現する - Qiita
##概要以下記事の補足というか、タイトル部分で痛い目を見たので専用記事。そのまんま、O…
SQL Server、というかマイクロソフト製品は痒い所に手が届かないものが多いので、その隙間を埋めるのは開発者の腕にかかっていると言えます。
参考リンク
トリガーの使用
![](https://stellacreate.com/wp-content/uploads/cocoon-resources/blog-card-cache/62becbf9e66edbd7a674a2191e28faef.png)
CREATE TRIGGER (Transact-SQL) - SQL Server
CREATE TRIGGER ステートメントの Transact-SQL リファレンス。DML、DDL、ログオン トリガーの作成に使用されます。