2008-11-05 49 views
3

我有一個簡單的數據庫:刪除記錄與外鍵 - 無效的轉換異常

ARTICLE 
---------- 
ArticleId (PK), 
ArticleTitle 
..other stuff... 

USER-ARTICLE 
------------ 
ArchiveId (PK), 
UserId, 
ArticleId 
..other stuff... 

articleId的外鍵。

我希望能夠通過使用下面的代碼UserArticleId刪除用戶物品列,

UserArticle myobjtodelete = PersonalArchiveDb.UserArticles.Single(ua => ua.ArchiveId == 3); 
PersonalArchiveDb.UserArticles.DeleteOnSubmit(myobjtodelete); 
PersonalArchiveDb.SubmitChanges(); 

(是的,我知道我能做到的聲明刪除裏面,而不是獲取對象,這是爲了調試的目的,以確保目標絕對存在 - 它)

當調試器到達的SubmitChanges()線,我得到一個運行時錯誤:

Specified cast is not valid.

這裏是堆棧跟蹤,

at System.Data.Linq.IdentityManager .StandardIdentityManager .SingleKeyManager`2.TryCreateKeyFromValues(Object[] values, V& v) at System.Data.Linq.IdentityManager.StandardIdentityManager.IdentityCache`2.Find(Object[] keyValues) at System.Data.Linq.IdentityManager.StandardIdentityManager.Find(MetaType type, Object[] keyValues) at System.Data.Linq.CommonDataServices.GetCachedObject(MetaType type, Object[] keyValues) at System.Data.Linq.ChangeProcessor.GetOtherItem(MetaAssociation assoc, Object instance) at System.Data.Linq.ChangeProcessor.BuildEdgeMaps() at System.Data.Linq.ChangeProcessor.SubmitChanges(ConflictMode failureMode) at System.Data.Linq.DataContext.SubmitChanges(ConflictMode failureMode)
at System.Data.Linq.DataContext.SubmitChanges() at Driver_SOC_ASO.Controls.PersonalArchive.ArchiveListing.grdArchive_RowDeleting(Object sender, GridViewDeleteEventArgs e) in C:\work\Driver.Net\Driver-SOC-ASO\Driver-SOC-ASO\Controls\PersonalArchive\ArchiveListing.ascx.cs:line 78 at System.Web.UI.WebControls.GridView.OnRowDeleting(GridViewDeleteEventArgs e) at System.Web.UI.WebControls.GridView.HandleDelete(GridViewRow row, Int32 rowIndex) at System.Web.UI.WebControls.GridView.HandleEvent(EventArgs e, Boolean causesValidation, String validationGroup) at System.Web.UI.WebControls.GridView.RaisePostBackEvent(String eventArgument) at System.Web.UI.WebControls.GridView.System.Web.UI.IPostBackEventHandler.RaisePostBackEvent(String eventArgument) at System.Web.UI.Page.RaisePostBackEvent(IPostBackEventHandler sourceControl, String eventArgument) at System.Web.UI.Page.RaisePostBackEvent(NameValueCollection postData)
at System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint)

我很茫然,什麼想法嗎?

+0

您的示例代碼使用「ArchiveId」而不是「ArticleId」 - 在您的原始描述中,您的意思是「存檔」而不是「文章」? – 2008-11-05 11:17:44

回答

0

嘗試設置ON CASCADE刪除ArticleId

1

這可能是這個bug的例子,微軟表示,固定在.NET 4.0。

0

在您的dbml中,檢查是否有不正確的關聯b/w Article和UserArticle。