• Expression2Sql的一些语法更新


    前言

      前一阵子给大家介绍了一个可以将Expression表达式树解析成Transact-SQL的项目Expression2Sql。
      之后得到了广大读者的一些好评,也使得博主更有动力继续更新下去,然后一些园友也给出了一些极具建设性的意见,也有部分园友反馈了一些bug。最近一段时间,博主也集中精力,抽出一些时间做了一次更新,本篇文章将介绍本次更新的内容
          简单易用,几分钟即可上手使用,因为博主在设计Expression2Sql的时候就尽可能的按照Transact-SQL的语法语义风格来设计,只要调用者熟悉基本的Transact-SQL语法即可瞬间无忧开码,大大降低了学习Expression2Sql的成本,甚至零成本。对象化操作,链式编程,支持多表复杂关联查询,任意组装sql,自动生成表别名,参数化赋值,防止sql注入,支持SQLServer、MySQL、Oracle、SQLite等多数据库,生成极度美观的sql字符串(格式化)等诸多优点。
      Expression2Sql的设计初衷就是职责非常单一、干净清爽,纯粹就是输入表达式树,然后经过它的解析之后,便可返回Transact-SQL给调用方。所以它的使用场景主要是用于和第三方的ORM或者是基于ado.net的原生DbHelper帮助类做对接,使其能够支持对象化、表达式树的链式编程。

          具体详情可以前往此篇博文一探究竟:介绍一个可以将Expression表达式树解析成Transact-SQL的项目Expression2Sql

     

        
          感谢大家踊跃提意见,不少园友建议用Expression2Sql打造一个O/R mapping数据访问组件,没错,这也是Expression2Sql的优势。
      可以,在下一篇博文中,博主就讲解 Expression2Sql + DbHelper + Mapping = ORM ,最大化解耦拆分成独立的组件。

      伪代码如下:

    public static List<T> Query<T>(ExpressionToSql<T> expression)
    {
        string sql = expression.Sql;
        DataTable dt = DbHelper.ExecuteDataTable(sql, expression.DbParams);
        List<T> list = Mapping.ToListEntity<T>(dt);
        return list;
    }

    在做形参赋值时报错,现已解决。



    对于括号优先级的处理,现已支持。

    增加Insert方法



    给查询字段取别名


    提供静态类和实例类的两种调用方式

    Expression2Sql组件的核心对象ExpressionToSql是实例类,调用的时候还得对象实例化,然后通过构造函数注入数据库sql语法分析器。但是博主考虑到很多时候,工作或学习当中,一般单数据库类型居多,所以使用静态类来调用,会非常的方便快捷。于是博主抛砖引玉,封装了基于SQLServer、MySQL、Oracle、SQLite数据库的的静态类。当然调用方可以借鉴这些静态类,自行封装这4种常用数据库之外的静态类。





    本文版权归作者 【陌城&心灵捕手】博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

  • 相关阅读:
    课后作业之找水王
    SCRUM第二阶段第十天
    第九周总结
    冲刺一3
    用户项目
    预会热词统计
    冲刺一2
    冲刺一(一阶)1
    第八周总结
    小组合作
  • 原文地址:https://www.cnblogs.com/StrangeCity/p/5142560.html
Copyright © 2020-2023  润新知