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