给各位聚聚和大大介绍一个开源项目 Expression2Sql(二)

hushi55 9年前

前一阵子给大家介绍了一个可以将Expression表达式树解析成Transact-SQL的开源项目Expression2Sql。

简单易用,几分钟即可上手使用,因为博主在设计Expression2Sql的时候就尽可能的按照Transact-SQL的语法语义风格来设计,只要调用者熟悉基本的Transact-SQL语法即可瞬间无忧开码,大大降低了学习Expression2Sql的成本,甚至零成本。对象化操作,链式编程,任意组装sql,自动生成表别名,参数化赋值,防止sql注入,支持SQLServer、MySQL、Oracle、SQLite等多数据库,生成极度美观的sql字符串(格式化)等诸多优点。

具体详情可以前往此篇博文一探究竟:

《给各位聚聚和大大介绍一个开源项目 Expression2Sql》

Expression2Sql源码托管地址: https://github.com/StrangeCity/Expression2Sql

诸多开源项目收录: http://www.cnblogs.com/StrangeCity/p/OpenSourceProject.html


之后得到了广大读者的一些好评,也使得博主更有动力继续更新下去,然后一些园友也给出了一些极具建设性的意见,也有部分园友反馈了一些bug。最近一段时间,博主也集中精力,抽出一些时间做了一次更新,本篇文章将介绍本次更 新的内容 。

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

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

三、增加Insert方法

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

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

 1 ExpressionToSql<UserInfo> userInfoSql = new ExpressionToSql<UserInfo>(new MySQLSqlParser());   2             Printf(   3                     userInfoSql.Select().Where(u => u.Id != 1),   4                     "查询单表,带where条件,实例类"   5             );   6    7    8             Printf(   9                ExpressionToSqlSQLServer.Select<UserInfo>().  10                                         Where(u => u.Name == "张三"),  11                "SQLServer静态类"  12             );
</div>

来自: http://www.cnblogs.com/StrangeCity/p/5142560.html