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种常用数据库之外的静态类。





转载于:https://www.cnblogs.com/StrangeCity/p/5142560.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值