【问题标题】:LINQtoSQL and SerializationLINQtoSQL 和序列化
【发布时间】:2011-11-04 03:06:12
【问题描述】:

我是 LINQtoSQL 的新手。我选择学习它是因为我没有太多用 SQL 编写存储过程的经验,并且认为 LINQtoSQL 可能是进行数据访问的另一种方式。无论如何,我创建了一个简单的 ASP.NET 应用程序,其中包含几个从用户那里收集一些数据的简单 Web 表单。

接下来,我将一个 LINQtoSQL 数据对象(一个 dbml 文件)添加到我的项目中。将它连接到我的 SQL 数据库中的数据源,并允许 OR/Designer 为我创建一个实体。一切似乎都好得令人难以置信。直到,我开始将我在 Web 表单中收集的数据保存回数据库。那是我开始了解 LINQtoSQL 的序列化问题的地方。

具体情况是我的网络表单分多个步骤收集数据。像任何 ASP 开发人员一样,我在浏览页面生命周期时将这些数据存储在 ViewState 中。最后,一旦我的 ViewState 拥有所需的所有数据,点击提交按钮以使用 LINQtoSQL 实体对象将其发送到数据库。这就是我开始得到序列化异常的地方:

System.Runtime.Serialization.SerializationException:在程序集“System.Data.Linq,版本=4.0.0.0,文化=中性,PublicKeyToken=b77a5c561934e089”中键入“System.Data.Linq.ChangeTracker+StandardChangeTracker”未标记为可序列化。

我在网上四处张望。我知道我的唯一一个 LINQtoSQL 实体(我从我的 ViewState 分配)是可序列化的,因为它是用必需的 DataContract 和 DataMember 属性装饰的。经过大量阅读后,我尝试了 Brain Orrell 在以下链接中提供的解决方案,该解决方案要求提供您自己的序列化程序。对于我想要实现的目标(将一段数据简单地写入数据库)似乎非常复杂,并且序列化异常仍然没有消失。虽然奇怪的是,我的实体现在已正确写入数据库:

http://borrell.parivedasolutions.com/2008/02/linq-to-sql-updating-in-aspnet-right.html

我的问题是,将 ViewState 数据传递给 LINQtoSQL 实体以便将其写入数据库的正确且简单的方法是什么。如果有人知道一个具体但很好的例子可以效仿,我将不胜感激。否则我可以从我自己的项目中发布代码,我们可以从那里开始。

谢谢提前。

菲克

【问题讨论】:

  • [DataContract] != [Serializable](更准确地说,标记为 [Serializable] 可以DataContractSerializer 处理,但标记为只有[DataContract] 不被[Serializable] 序列化程序处理(如BinaryFormatter)。)

标签: asp.net linq-to-sql data-access


【解决方案1】:

Kirk 的评论实际上是对您问题的回答。我只是再给你一个建议——如果你是 ORM 中的“tabula rasa”,请尽快忘记使用 LinqToSql 的不愉快体验,并尝试新的实体框架。它是更强大、更灵活的解决方案(具有类似的视觉设计器和围绕它的“魔术”),但它允许您使用 POCO 作为您的实体类 - 您可以使其可序列化,或以任何其他需要的方式对其进行调整。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2010-09-13
    • 2014-08-24
    • 1970-01-01
    • 2010-10-07
    • 2012-03-17
    相关资源
    最近更新 更多