【发布时间】: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