我需要读取从外部系统发布的XML数据,其格式大致如下:
<Applicant>
<FirstName>John</FirstName>
<LastName>Smith</LastName>
<Address>12 Main St</Address>
</Applicant>
这是我的Linq到SQL Applicant类的直接映射,不包括一些属性。
将xml反序列化为Linq to SQL对象的最佳方法是什么,然后我可以直接插入到我的数据库中?我还想验证传入的XML并尽可能处理特定的错误。
提前致谢!
答案 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表示...
希望有所帮助