将xml反序列化为Linq to SQL对象

时间:2010-01-17 17:16:00

标签: c# linq-to-sql xml-serialization

我需要读取从外部系统发布的XML数据,其格式大致如下:

<Applicant>
  <FirstName>John</FirstName>
  <LastName>Smith</LastName>
  <Address>12 Main St</Address>
</Applicant>

这是我的Linq到SQL Applicant类的直接映射,不包括一些属性。

将xml反序列化为Linq to SQL对象的最佳方法是什么,然后我可以直接插入到我的数据库中?我还想验证传入的XML并尽可能处理特定的错误。

提前致谢!

3 个答案:

答案 0 :(得分:3)

如果它是直接映射,您应该只能直接使用它,只要类型为public且具有公共无参数构造函数,并且属性(包括列表)是get / set。

如果需要调整名称,可以使用XmlSerializer构造函数来指定所有属性。这对于您的场景非常理想,但是如果您使用此构造函数重载,则必须缓存并重新使用序列化程序,否则您将泄漏内存(不收集动态程序集)。

这是一个完整的示例,它删除一个属性(XmlIgnore),将另一个属性更改为属性,并将第三个属性作为元素。

using System;
using System.IO;
using System.Xml.Serialization;
public class Foo
{
    public int A { get; set; }
    public string B { get; set; }
    public int C { get; set; }
}
static class Program
{
    static readonly XmlSerializer serializer;
    static Program()
    {
        XmlAttributeOverrides or = new XmlAttributeOverrides();
        or.Add(typeof(Foo), "A", new XmlAttributes { // change to an attrib
            XmlAttribute = new XmlAttributeAttribute("tweaked")
        });
        or.Add(typeof(Foo), "B", new XmlAttributes {
            XmlIgnore = true // turn this one off
        });
        // leave C as a default named element
        serializer = new XmlSerializer(typeof(Foo), or);
    }
    static void Main()
    {
        Foo foo = new Foo { A = 123, B = "def", C = 456 }, clone;
        string xml;
        using (StringWriter sw = new StringWriter())
        {
            serializer.Serialize(sw, foo);
            xml = sw.ToString();
        }
        using (StringReader sr = new StringReader(xml)) {
            clone = (Foo)serializer.Deserialize(sr);
        }
        Console.WriteLine(xml);
        Console.WriteLine();
        Console.WriteLine(clone.A);
        Console.WriteLine(clone.B);
        Console.WriteLine(clone.C);
    }
}

另请注意,如果您只需要更改类型级别的内容(例如[XmlInclude]),那么您可以通过LINQ-to-的partial class来完成此操作SQL生成;例如:

namespace My.Dal.Namespace {
    // add a type attribute to SomeEntity
    [XmlInclude(typeof(SomeDerivedEntity))]
    partial class SomeEntity { } 
}

答案 1 :(得分:0)

要验证,您需要为这些XML文件提供XML模式 - 您可以使用Windows SDK目录中的xsd.exe工具轻松创建一个XML模式,该工具获取XML文件并将其转换为xsd(XML架构)。

如果你已经有一个基本上匹配这个XML的类,是的,最简单的可能是将它反序列化为Applicant类:

XmlSerializer ser = new XmlSerializer(typeof(Applicant));
StreamReader sr = new StreamReader(.....); // depends on where you get your XML from
Applicant result = (Applicant)ser.Deserialize(sr);

这应该用来自XML的那些属性来填充你的Applicant对象 - 只要你没有将任何必需的属性留空(并且没有办法提供有效的默认值),这将有效如果您的映射中没有任何类型不匹配(例如,尝试将字符串反序列化为INT属性或类似的东西)。

答案 2 :(得分:0)

它更简单。

首先使用DataContractSerializer来序列化LinqToXml实体。 这将返回一个字节数组。 使用Encoding.UTF8.GetString(来自DataContractSerializer的字节数组),您将获得实体的xml表示...

希望有所帮助