gpt4 book ai didi

asp.net - LINQtoSQL 和序列化

转载 作者:行者123 更新时间:2023-12-02 14:58:40 27 4
gpt4 key购买 nike

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

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

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

System.Runtime.Serialization.SerializationException:程序集“System.Data.Linq,Version=4.0.0.0,Culture=neutral,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 实体以便将其写入数据库的正确且简单的方法是什么。如果有人知道一个具体但很好的例子可以遵循,我将不胜感激。否则,我可以发布我自己项目中的代码,我们可以从那里开始。

感谢您的提前。

菲克

最佳答案

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

关于asp.net - LINQtoSQL 和序列化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7198346/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com