数据库
首页 > 数据库> > xml反序列化为Linq to SQL对象

xml反序列化为Linq to SQL对象

作者:互联网

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

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

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

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

提前致谢!

解决方法:

如果它是直接映射,则只要它是公共类型并且具有公共无参数构造函数,并且属性(包括列表)是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-SQL生成的部分类来完成;例如:

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

标签:xml-serialization,linq-to-sql,c
来源: https://codeday.me/bug/20191210/2100937.html