HTML5技术

给各位聚聚和大大介绍一个开源项目 Expression2Sql(二) - 陌城心灵捕手

字号+ 作者:H5之家 来源:博客园 2016-01-22 17:00 我要评论( )

前一阵子给大家介绍了一个可以将Expression表达式树解析成Transact-SQL的开源项目Expression2Sql。 之后得到了广大读者的一些好评,也使得博主更有动力继续更新下去,然后一些园友也给出了一些极具建设性的意见,也有部分园友反馈了一些bug。最近一段时间,

      前一阵子给大家介绍了一个可以将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帮助类做对接,使其能够支持对象化、表达式树的链式编程。

      具体详情可以前往此篇博文一探究竟:《给各位聚聚和大大介绍一个开源项目 Expression2Sql》 

  Expression2Sql源码托管地址:https://github.com/StrangeCity/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种常用数据库之外的静态类。





 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • HTML5移动开发中的meta与link - 大大白兔子

    HTML5移动开发中的meta与link - 大大白兔子

    2015-10-10 15:12

  • HTML5移动开发中的input输入框类型 - 大大白兔子

    HTML5移动开发中的input输入框类型 - 大大白兔子

    2015-10-08 08:26

  • Google宣布Web已经胜利 HTML 5将Web大大推进

    Google宣布Web已经胜利 HTML 5将Web大大推进

    2014-11-17 18:29

网友点评
t