AbstractClassBuilder.cs 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. using System.Data;
  7. using System.Xml;
  8. namespace WebAPIBase.NetCore.BusinessCore
  9. {
  10. public abstract class AbstractClassBuilder : IClassBuilder
  11. {
  12. public AbstractClassBuilder()
  13. {
  14. }
  15. public abstract EntityData BuildClass(string className);
  16. protected virtual DataTable BuildTable(XmlNode tablenode)
  17. {
  18. try
  19. {
  20. XmlNodeList xmlNodeList = tablenode.SelectNodes("Column");
  21. int count = xmlNodeList.Count;
  22. if (count == 0)
  23. {
  24. throw new ApplicationException("没有定义字段");
  25. }
  26. DataTable dataTable = new DataTable(tablenode.SelectSingleNode("Name").InnerText);
  27. int count2 = tablenode.SelectNodes("Column[IsKey='true']").Count;
  28. DataColumn[] array = new DataColumn[count2];
  29. int num = 0;
  30. for (int i = 0; i < count; i++)
  31. {
  32. DataColumn dataColumn = new DataColumn(xmlNodeList[i].SelectSingleNode("Name").InnerText);
  33. string innerText = xmlNodeList[i].SelectSingleNode("DataType").InnerText;
  34. dataColumn.DataType = Type.GetType(innerText);
  35. if ("System.String" == innerText)
  36. {
  37. dataColumn.MaxLength = int.Parse(xmlNodeList[i].SelectSingleNode("ColumnSize").InnerText);
  38. }
  39. if ("true" == xmlNodeList[i].SelectSingleNode("IsKey").InnerText)
  40. {
  41. array[num] = dataColumn;
  42. num++;
  43. }
  44. dataTable.Columns.Add(dataColumn);
  45. }
  46. if (count2 > 0)
  47. {
  48. dataTable.PrimaryKey = array;
  49. }
  50. return dataTable;
  51. }
  52. catch (Exception ex)
  53. {
  54. throw ex;
  55. }
  56. }
  57. protected virtual XmlNode GetXmlRoot(string className)
  58. {
  59. XmlDocument xmlDoc = XmlDefineFileManage.GetXmlDoc(className);
  60. return xmlDoc.DocumentElement;
  61. }
  62. public virtual SqlStruct GetSqlStruct(string className, string sqlStringName)
  63. {
  64. return SqlManager.GetSqlStruct(className, className, sqlStringName);
  65. }
  66. }
  67. }