DbExpressionTranslator.cs 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. using Ant.Core;
  2. using Ant.Data;
  3. using Ant.DbExpressions;
  4. using Ant.Infrastructure;
  5. using Ant.ORM;
  6. using System;
  7. using System.Collections.Generic;
  8. using System.Linq;
  9. using System.Text;
  10. using System.Threading.Tasks;
  11. namespace Ant.SqlServer
  12. {
  13. /// <summary>
  14. /// ORM首先调该类进行SQL语句的解析(ORM的入口)
  15. /// </summary>
  16. class DbExpressionTranslator : IDbExpressionTranslator
  17. {
  18. public static readonly DbExpressionTranslator Instance = new DbExpressionTranslator();
  19. /// <summary>
  20. /// 返回拼接的SQL语句
  21. /// </summary>
  22. /// <param name="expression"></param>
  23. /// <param name="parameters"></param>
  24. /// <returns></returns>
  25. public string Translate(DbExpression expression, out List<DbParam> parameters)
  26. {
  27. SqlGenerator generator = SqlGenerator.CreateInstance();//构建SQL数据库类
  28. expression.Accept(generator);
  29. parameters = generator.Parameters;
  30. string sql = generator.SqlBuilder.ToSql();
  31. return sql;
  32. }
  33. }
  34. /// <summary>
  35. /// ORM实现SQL2012数据库的带分页查询类
  36. /// </summary>
  37. class DbExpressionTranslator_OffsetFetch : IDbExpressionTranslator
  38. {
  39. public static readonly DbExpressionTranslator_OffsetFetch Instance = new DbExpressionTranslator_OffsetFetch();
  40. /// <summary>
  41. /// 返回拼接的SQL语句
  42. /// </summary>
  43. /// <param name="expression"></param>
  44. /// <param name="parameters"></param>
  45. /// <returns></returns>
  46. public string Translate(DbExpression expression, out List<DbParam> parameters)
  47. {
  48. SqlGenerator_OffsetFetch generator = new SqlGenerator_OffsetFetch();
  49. expression.Accept(generator);
  50. parameters = generator.Parameters;
  51. string sql = generator.SqlBuilder.ToSql();
  52. return sql;
  53. }
  54. }
  55. }