CREATE TRIGGER update_room_status AFTER INSERT ON `Order` FOR EACH ROW BEGIN UPDATE Room SET RoomStatus = '已预订' WHERE RoomID = NEW.RoomID; END;在sql server 中运行应该怎么改
时间: 2024-02-13 11:05:59 浏览: 195
Node.js使用orm2进行update操作时关联字段无法修改的解决方法
在 SQL Server 中,需要将该 MySQL 触发器代码进行转换才能使用。转换后的 SQL Server 触发器代码如下所示:
```
CREATE TRIGGER update_room_status ON [Order] AFTER INSERT AS
BEGIN
UPDATE Room SET RoomStatus = '已预订' WHERE RoomID = (SELECT RoomID FROM inserted);
END;
```
该触发器的作用和 MySQL 触发器相同,即在 `Order` 表中插入新数据后,自动更新 `Room` 表中对应房间的状态为“已预订”。具体实现方式是通过 `UPDATE` 语句修改 `Room` 表中符合条件的数据,其中 `(SELECT RoomID FROM inserted)` 表示触发器中插入的新数据的 `RoomID` 字段。在 SQL Server 中,`inserted` 是一个临时表,用于存储插入操作中的所有新增数据。
阅读全文