在ATK-DataPortal框架中的xxxHandel中常用到的一种类型,形如:

1、protected virtual D ItemHandle(D item, Func<E, E> dataportalhandle, ExpConditions<D> znexp)

{

E bllitem = item.CopyToIn();

ApplyContext(bllitem);

bllitem.Criteria = BusinessCriteria.BusinessCriteriaCreate(znexp);

bllitem = dataportalhandle(bllitem);

return item.CopyToOut(bllitem);

}

2、 public ExpConditions<D> GetExp()

{

return new ExpConditions<D>();

}

以上两例中的 ExpConditions<D>  是定义在 Atk.CustomExpression库中。ExpConditions<D>是一个Lambda表达式转SQL语句的功能类。

在分布式环境中,数据层到业务层的访问往往需要在不同物理层中传输。在.NET中常见的ORM是EF,EF的功能和优点不在本文描述之内,EF本现一进程中传递时,是没有任何问题的,但在不同物理层中,需要通过WCF之类的服务来传输时,问题就显而易见,EF的序列化和反序列化在WCF不易实现,同时在多层设计中,前端的类型过重的传入到数据层也是不合理的,容易形成强绑定,不合符分布设计中服务自治原则。如果不能解决好跨进程跨服务问题,应用就很可能是常见的三层结构,且前后端存在类型强绑定。我们习惯用强类型来编程,这样在类型检查、变更时会有很大的使得。

Atk.CustomExpression库能将将我们在前端所使用的Lambda表达式转SQL子句。SQL子句是string类,这样在序列化和反序列化就变得很容易,只要我们的数据层支持支持使用SQL来操作作数,EF和System.Data.SqlClient都是支持执行原始sql语句操作的。

Atk.CustomExpression库

一、可以达到的功能

本功能类库主要提供给代码中使用Lambda表达式,后需转成SQL的条件语句这一需求

二、不能做的

1、本类库不能解析Linq语句

2、不能解析SQL中的Select部分

例1:

class A

{

public Int16 Id { get; set; }

public string name { get; set; }

public string sex { get; set; }

}

ExpConditions<A> expa = new ExpConditions<A>();

expa.AddAndWhere(s => s.Id == 123 && s.name.Contains("a"), Alias.a2);

expa.UpdateFields(s => new { s.Id, s.sex }, Alias.a2);

结果生成下列两个语句:

1、Where (([a2].[Id] = 123) and ([a2].[name] LIKE '%' + 'a' + '%'))

2、[a2].[Id] = @Id,[a2].[sexA] = @sex

例2:

// 当需要多子句拼接时,自动合并成合适的子句,如 Where ,不会出现多个“where”关键词。

ExpConditions<A> expa2 = new ExpConditions<A>();

if (1==1)

{

expa2.AddAndWhere(s => s.Id == 123);

}

if (2==2)

{

expa2.AddAndWhere(s => s.name.Contains("a"));

}

结果生成下列两个语句:

Where ([a0].[Id] = 123) And ([a0].[name] LIKE '%' + 'a' + '%')

----

ATK

1、一个完整支持分布式服务框架;

2、代码生成工具,可快速生成基于服务框架的应用;

3、其他支持库

4、完整代码可在GitHub的https://github.com/azthinker ;开源中国 https://gitee.com/azthinker

目标:使应用开发,低代码、高效率、快迭代

有兴趣的请在QQ群中参与讨论、联系作者  QQ群名称:ATK高效开发 ,QQ群号:747049962

也可发邮件至:azthinker@sina.com

Demo中的数据库、编译好的代码工具链接:https://pan.baidu.com/s/1B9RQm7_-SFyhLb_HLIGs0w 密码:85q6

ATK Demo使用的数据库 : https://download.csdn.net/download/xftyyyyb/10675497

ATK自动代码工具 :https://download.csdn.net/download/xftyyyyb/10675490

ATK 设计框架 之 Atk.CustomExpression的更多相关文章

  1. ATK 设计框架辅助工具-代码生成器

    在 ATK框架代码中的示例,是用代码生成器生成的. 示例中有三个项目DemoTools.BLL 业务层,DemoTools.UIServer 前端服务层,DemoTools.WebUI 前端是ASP. ...

  2. Origami – 用于 Quartz 的免费的交互设计框架

    Origami 是一个为 Quartz Composer 开发的免费的工具包——由Facebook设计团队创建,让交互设计原型更加简单,不需要编程. 如今,大多数设计师通过创建静态原型来表达要实现的应 ...

  3. SOA之(2)——SOA架构基础概念与设计框架

    SOA的设计框架 设计框架与架构相关的概念紧密相连,原则.模式和架构始终是与设计共舞的. SOA服务设计的原则中记录了一个基础的设计框架: 设计特性(Design Characteristic)——由 ...

  4. 仿知乎app登录界面(Material Design设计框架拿来就用的TexnInputLayout)

    在我脑子里还没有Material Design这种概念,就我个人而言,PC端应用扁平化设计必须成为首选,手当其冲的两款即时通讯旺旺和QQ早就完成UI扁平化的更新,然而客户端扁平化的设计本身就存在天生的 ...

  5. Spark ML源码分析之一 设计框架解读

    本博客为作者原创,如需转载请注明参考           在深入理解Spark ML中的各类算法之前,先理一下整个库的设计框架,是非常有必要的,优秀的框架是对复杂问题的抽象和解剖,对这种抽象的学习本身 ...

  6. 基于事件驱动的DDD领域驱动设计框架分享(附源代码)

    原文:基于事件驱动的DDD领域驱动设计框架分享(附源代码) 补充:现在再回过头来看这篇文章,感觉当初自己偏激了,呵呵.不过没有以前的我,怎么会有现在的我和现在的enode框架呢?发现自己进步了真好! ...

  7. ATK-DataPortal 设计框架(三)

    边界清晰.服务自治.契约共享.基于策略的兼容性,是面向对向设计时四个基本原则,我们的应用可能分布在不同的环境之中,应用可能在同一服务器中,也可能在不同的网络环境中,保证框架的基类能在不同环境中仍然可用 ...

  8. ATK-DataPortal 设计框架(二)

    在信息的交换过程中,总是有此相同相似的功能,由于业务的各自不同,由同一类型来处理诸如增删改查等常见的信息处理方式.从日常的对些类行为操作为生成的类分析,大量雷同的代码遍布整个项目.框架中xxxHand ...

  9. ATK-DataPortal 设计框架(一)

    无论是简单的还是复杂的框架,总需要一个开始的原点,ATK-DataPortal中包含了所有基础类的定义. 一.业务框架基础类 1.BusinessBase:所有业务类的根类,要使用ATK库的类,必需继 ...

随机推荐

  1. java中json解析,xml解析

    抓取网页内容,会返回json或者xml(html)格式的数据. 为了方便的对上述两种格式的数据进行解析,可采用解析工具. JsonPath https://github.com/jayway/Json ...

  2. [转]谷歌Chrome浏览器开发者工具教程—JS调试篇

    来源:http://blog.csdn.net/cyyax/article/details/51242720 上一篇我们学习了谷歌Chrome浏览器开发者工具的基础功能,下面介绍的是Chrome开发工 ...

  3. OC与JS交互之WebViewJavascriptBridge

    上一篇文章介绍了通过UIWebView实现了OC与JS交互的可能性及实现的原理,并且简单的实现了一个小的示例DEMO,当然也有一部分遗留问题,使用原生实现过程比较繁琐,代码难以维护.这篇文章主要介绍下 ...

  4. WSAAsyncSelect 消息模型

    select 模型虽然可以管理多个socket,但是它涉及到一个时机的问题,select模型会针对所管理的数组中的每一个socket循环检测它管理是否在对应的数组中,从时间复杂度上来说它是O(n^2) ...

  5. 从零开始的全栈工程师——jQuery

    jQueryjq是js一个高效且精简的库( 用的多写得少 ) ,是chrome出版的.jq内部有一个$的方法,他是jq的起始符或标识符,这个方法是用于获取元素. 下载库或者框架的方法官网 produc ...

  6. Jmeter各部件的作用

    JMeter主要组件介绍 1.测试计划(Test Plan)是使用 JMeter 进行测试的起点,它是其它 JMeter 测试元件的容器. 2.线程组(Thread Group)代表一定数量的并发用户 ...

  7. Siebel应用数据结构层次

    在Siebel应用里数据在多个层次上使用了不同的定义方式,每一个层次侧重于数据的不同的特征,主要分为数据用户界面层定义(UI),业务逻辑层定义(Business Layer,可以是业务含义层)以及数据 ...

  8. 【Leetcode】【Easy】Remove Duplicates from Sorted List

    Given a sorted linked list, delete all duplicates such that each element appear only once. For examp ...

  9. static final int DEFAULT_INITIAL_CAPACITY = 1 << 4; // aka 16

    查看HashMap源码,发现这个static final int DEFAULT_INITIAL_CAPACITY = 1 << 4;  值为16. 这个是位移算法. 例如: 4<& ...

  10. 一点一点学写Makefile-1

    相信很多Linux开发者 都得自己来写Makefile,刚开始学习学写这个的时候都会碰到很多困难,我之前没有自己独立完成过Makefile,都是在公司已有的模板上添加.现在突然有一个很大的想法就是从零 ...