插入到具有而不是来自实体数据框架的触发器的表时出错

2023-12-29

我正在使用实体框架4,在使用实体框架在具有替代插入触发器的表中插入新记录时,当表具有标识列时,替代触发器用于根据特定逻辑修改插入的值之一,实体框架引发异常“存储更新、插入或删除语句影响了意外数量的行 (0)。实体加载后可能已被修改或删除。刷新 ObjectStateManager 条目”。

任何人都可以帮助如何解决此异常吗?


使用 Entity Framework 4.1,Ladislav 发布的解决方案将 Scope_Identity() 的 Select 添加到触发器主体的末尾,为我解决了这个问题。为了完整起见,我已在此处复制了整个触发器创建过程。通过这个触发器定义,我可以使用 context.SaveChanges() 将行添加到表中。

ALTER TRIGGER [dbo].[CalcGeoLoc]
   ON  [dbo].[Address]
   INSTEAD OF INSERT
AS 
BEGIN
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT OFF;

-- Insert statements for trigger here
INSERT INTO Address (Street, Street2, City, StateProvince, PostalCode, Latitude, Longitude, GeoLoc, Name)
SELECT Street, Street2, City, StateProvince, PostalCode, Latitude, Longitude, geography::Point(Latitude, Longitude, 4326), Name 
FROM Inserted;

select AddressId from [dbo].Address where @@ROWCOUNT > 0 and AddressId = scope_identity();
END

编辑以处理计算值(感谢评论中的克里斯·摩根):

如果表中有任何其他计算值,则也必须将它们包含在 SELECT 中。例如,如果您有一个CreatedDate使用的列GETDATE()你可以像这样进行选择:

SELECT [AddressId], [CreatedDate] from [dbo].Addresses where @@ROWCOUNT > 0 and AddressId = scope_identity();
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

插入到具有而不是来自实体数据框架的触发器的表时出错 的相关文章

随机推荐