首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >实体框架4变更审核

实体框架4变更审核
EN

Stack Overflow用户
提问于 2011-10-17 14:48:26
回答 3查看 1.1K关注 0票数 0

我有一个使用EF4的web应用程序。我是EF的新手,现在正在尝试实现change Audit.I。我尝试通过捕获Context类的SavingChanges事件来实现,如下所示

代码语言:javascript
运行
复制
partial void OnContextCreated()
        {
            this.SavingChanges += new EventHandler(TicketContainer_SavingChanges);

        }

因此,事件处理程序通过以下方法访问已更改的记录

代码语言:javascript
运行
复制
this.ObjectStateManager.GetObjectStateEntries(
             EntityState.Added | EntityState.Modified);

这很好用,我正在为选定的表创建列级审计。每个表/实体都有一个ID字段,它是一个带有columnName="ID“的标识符。因此,在我的审计例程中,我只是访问名为" ID“的列中的数据,以获得审计记录的ID。

我面临的问题是在插入过程中。新记录还没有ID,因为它是数据库中的标识列,并且始终为0。

我能想到的一个解决方案是对所有Ids.But使用GUID。有没有一种方法可以使用标准的int32身份I来实现这一点?

谢谢

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-10-17 15:37:36

当我们通过EF插入数据时,插入时不会生成identity列。为了得到Identity列的Id,我们必须先插入数据,然后才能获得coulmn的Id。

请阅读下面可能对您有帮助的内容。http://www.codeproject.com/KB/database/ImplAudingTrailUsingEFP1.aspx

票数 1
EN

Stack Overflow用户

发布于 2011-10-17 15:01:30

我现在不知道你有多少个实体,但在我们自己的审计跟踪实现中,我们为每个实体创建了一个特定的审计实体,以便我们可以通过导航属性将它们链接在一起,并让数据库设置身份键。

如果您对审计实体使用继承,那么很容易对它们进行查询。

希望这能有所帮助:)

票数 0
EN

Stack Overflow用户

发布于 2011-10-17 15:43:37

插入时不生成标识列。插入数据后,只有您可以在EF中获取标识列数据。因此,您可以尝试一些变通方法,在插入后获取Id,然后用该Id填充audit表。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7790251

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档