关于Schema包装库(C#)
从XML Schema类型到C#数据类型的默认映射如下:
XML Schema | C# | 备注 |
---|---|---|
xs:string | 字符串 | |
xs:boolean | bool | |
xs:decimal | decimal | xs:decimal没有范围和精度限制,映射到decimal以提高效率。 |
xs:float, xs:double | double | |
xs:long | long | |
xs:unsignedLong | ulong | |
xs:int | int | |
xs:unsignedInt | uint | |
xs:dateTime, date, time, gYearMonth, gYear, gMonthDay, gDay, gMonth | ||
xs:duration | ||
xs:hexBinary and xs:base64Binary | byte[] | 二进制数据的编码和解码都是自动完成的。 |
xs:anySimpleType | 字符串 |
未包含在列表中的所有XML Schema类型都是派生类型,并且映射到与相应基类型相同的C#类型。
生成的类
为Schema中的每个类型都会生成一个类,其中包含该类型的每个属性和元素的成员。这些成员被赋予与原始Schema中的特性或元素相同的名称(为了避免可能的冲突,追加了一个数字)。对于简单类型,将生成赋值和转换运算符。对于具有枚举方面的简单类型,可以使用GetEnumerationValue()和SetEnumerationValue(int)方法以及为每个枚举值生成的常量。此外,还可以使用StaticInfo()方法通过以下类型之一访问Schema信息:
从复杂类型生成的类包含SetXsiType()方法,它允许您设置该类型的xsi:type特性。当您想从派生类型创建XML实例元素时这一方法将十分有用。
除了在XML Schema中声明的类型的类以外,还会生成一个文档类(在下文中用“Doc”标识)。它包含所有可能的根元素作为成员,以及各自其他方法。有关该类的更多信息,请参见[YourSchema].[Doc]。
提示: 实际的类名称取决于.xsd schema的名称。
对于Schema类型的每个成员特性或元素,将生成一个新的类。有关该类的更多信息,请参见:
[YourSchemaType].MemberAttribute
[YourSchemaType].MemberElement
提示: 实际的类名取决于Schema特性或元素的名称。
处理错误
错误由异常报告。在命名空间Altova中定义了以下异常类:
Class | 基类 | 描述 |
---|---|---|
ConversionException | Exception | 类型转换失败导致出现异常。 |
StringParseException | ConversionException | 词法空间中的值无法转换为值空间。 |
DataSourceUnavailableException | System.Exception | 加载XML实例时出现问题。 |
DataTargetUnavailableException | System.Exception | 保存XML实例时出现问题。 |
此外,通常使用以下.NET异常:
Class | 描述 |
---|---|
System.Exception | 运行时错误的基类。 |
System.ArgumentException | 使用无效的参数值调用了一个方法,或类型转换失败。 |
System.FormatException | 词法空间中的值无法转换为值空间。 |
System.InvalidCastException | 值无法转换为另一个类型。 |
System.OverflowException | 无法在目标域中表示源值。 |
访问Schema信息
可以使用生成的库通过以下类访问静态Schema信息。
如果不存在相应的属性,则返回任何元数据类的属性会返回NULL。