实体框架6代码优先触发器

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (58)

我正在使用Entity Framework 6 Code First,并且想要创建一个Trigger。

我该怎么做呢?

我需要触发器的原因是因为用户可能直接编辑数据库或通过我正在编写的程序编辑数据库,我需要确保表中的2列不是空的,并且都不是空的。

我一直在寻找,找不到办法。

有没有办法先使用代码指定触发器?

提问于
用户回答回答于

实体框架不支持触发器,尽管您当然可以手动执行将创建触发器的语句,但您需要在创建表之后执行此操作(如果使用迁移)。

您可以在EF 4.1代码中使用Ladislav指定的技术- 首先向表中添加触发器

请注意他的警告,但EF不会知道触发器中的任何更改。如果您的意图仅仅是确保表中的2列不为空,那么您最好使用约束(EF不支持约束,但您可以手动添加它们)。

用户回答回答于

添加迁移后,打开迁移文件并创建触发器,如下所示

注意:您需要运行update-database才能查看数据库中的更改。

扫码关注云+社区

领取腾讯云代金券