您的位置:首页 > 编程语言 > C#

XSD文件生成C#VO实体类

2016-03-06 21:33 267 查看
  最近公司要做一个项目,需要和现有的其他项目对接,由于不知道他们的数据库,只有XSD文件。所以,我们在修改相应的程序时,就需要根据他们提供的XSD文件,来写我们的VO实体类,由于我写过根据Oracle数据库生成VO实体类,因此这次的这个活也就很自然的落在了我的头上。

[b]一、XSD[/b]

  首先什么是XSD,我就不解释了,因为我也不是很清楚,第一次接触,具体的详解度娘一下很多,XSD是XML Schema Definition 的简称,既然是XML,那读取方式,就按照XML的方式就可以了。

[b]二、解析的XSD文件[/b]

  我要解析的XSD文件是如下这个样子的,大家可以看到这个这个文件还需要加载两个xsd文件,但是通过我们的分析,对于我们这个项目来说,如果要生成实体类,除了需要解析下面这个图示XSD以外,还需要解析一个type类型xsd,也就是图中include的第二个xsd文件。

要解析的XSD

  先来看看上面这个VO实体类文件,通过截图,可以看出来,这个是一个VO实体类包含了好多个字段,但是每个字段的type又没有表示出来,因此需要到下面这个截图的xsd里去寻找,因为下图中的name对应着上图中的type,而下图中的base正是我们需要的字段类型。

private void ReplaceContent(AnalysisVo node)
{
//正常在基础的字段表中存在
if (DicType.ContainsKey(node.Type))
{
node.Type = DicType[node.Type];
}//要解析的里面没有type字段,只有name字段   yanc 20160304
else if (string.IsNullOrEmpty(node.Type) && DicType.ContainsKey(node.Name))
{
node.Type = DicType[node.Name];
}
else//List类型的没有存储在基础的字段表中,需要循环遍历本身的List列表
if(!string.IsNullOrEmpty(node.Type)&&(node.Type.Substring(node.Type.Length - 4, 4).Equals("Grid") || node.Type.Substring(node.Type.Length - 4, 4).Equals("List")))
{
foreach (var root in VoList)
{
if (root.Name.Equals(node.Type))
{
node.Type = root.Children.First().Type;
}
}
}//要解析的里面没有type字段,只有name字段   yanc 20160304
else if(string.IsNullOrEmpty(node.Type) && (node.Name.Substring(node.Name.Length - 4, 4).Equals("Grid") || node.Name.Substring(node.Name.Length - 4, 4).Equals("List")))
{
foreach (var root in VoList)
{
if (root.Name.Equals(node.Name))
{
node.Type = root.Children.First().Name;
}
}
}
else
{
Console.WriteLine("未能转化的内容" + node.Name);
}
}


View Code
  在替换的过程中,会有一种情况,即一个实体类中包含List<>泛型集合,我相信大家在开发过程中,见过这种情况,因此,在替换的时候,需要判断一下,通过我们的分析,一般这种的字段type是在基础类中找不到的,而是在当前的文件中进行查找,因此,当遇到的时候,还需要再次循环一遍自身集合,从而找到实体集合,将他的Name属性赋值给当前的Type字段。

[b]四、生成CS文件[/b]

  最后一步,就是生成CS文件了,和我上一篇文章大同小异,不过有一点需要注意,因为数据库生成的实体类是没有List类型的,但是这个XSD生成的有,因此需要稍加变动一下生成方法。

注:以上解析方法,同样适用于下图的一般request和response文件,特殊的需要另当处理。





五、Demo效果图



一个XSD生成了多个VO文件,每一个VO就是一个实体类





代码在GitHub上,希望大家一起帮忙修改,毕竟foreach嵌套foreach效率不是很高。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: