项目地址 :  https://github.com/kelin-xycs/SelectDataTable

SelectDataTable

一个 用 C# 实现的 用 Sql select DataTable 资料 的 程序

这是一个 用 C# 实现的 用 Sql select DataTable 资料 的 程序 。 最初的 目的 是 为 面向 数据集 的 开发 提供一个方便的工具 。
后来 衍生出了 语法分析 编译原理 的 内容 。

面向 数据集 的 开发 , 简单讲 可以 就是 Sql + DataTable 。 这是一种 简单直接 的 开发方式 。

Sql 是 开发人员 信手拈来 的 技能, 也是一个 成熟的 通用的 接口 。 用 Sql 操作 数据集 会 很方便 。

这个程序 支持 简单的 select 语句 , 支持 + - * / and or not = > < >= <= != 运算 。

支持 * 号 (表示要 select 全部 栏位) 。

支持 中括号 [] , 比如 栏位名 和 关键字 重名, 可以用 中括号 [] 括起来 。

Sql 中 from 关键字 后面 的 表名 是 “dt” , 这是 固定 的 。

select 的 结果 是 一个 新的 DataTable 。

支持 用 字符串 表示 日期时间 格式 。 比如 where create_date > '2016-07-08' 。
会判断 与之比较的 栏位 如果是 DateTime 类型 , 则 把 字符串 转为 DateTime 类型 再进行 比较 。

计划支持 sum() count() 等 函数 , 以及 group by order by , 目前 还 没有支持 。 这些特性 应该会比较有 实用价值 。

不支持 表连接 。 基本上, 未来也不会支持。 ^^ 因为 表连接 会 让事情变得复杂 。 在 应用程序层 没有索引 的 情况 下 做 表连接 会变得 效率低下 。 表连接 还是 放在 关系数据库 里 进行 比较好 。

不支持 子查询 。 子查询 也是 复杂的 。 实际中 可以 对 select 返回 的 DataTable 再 select 就行 。

这个程序 的 核心部分 是 Sql 解析部分 。 这部分 以及可以作为一个 简单的 语法分析器 了。 ^^

Sql 解析部分 的 设计 如下 :

有 3 个 解析类 : Parser, ExpressParser, SqlParser 。

Parser 是 基本 的 解析类, 负责 分词(Word) 和 获取 包裹符(Wrapper) 内 的 内容(Content) 。

这里 的 词(Word) 不是 单词, 是指 有意义的一个文本段落 。 分词规则 根据 语法规则 而定 。

比如 在 Sql 里, 是 根据 包裹符(Wrapper) 和 白空(White Space) 来 分词 。 在 C\C++ 里, 是 根据 大括号{} 和 分号; 来 分词 。

在 SelectDataTable 里 , 首先, 根据 包裹符 分词, 包裹符 有 3 种 : 单引号' 中括号[] 小括号() 。

根据 包裹符 分词 以后, 可以 得到 未被包裹(NonWrapped) 的 Word , 那么,就在 未被包裹 的 Word 里 寻找 关键字, 比如 select from where 等 。

然后 根据 关键字 再 分词, 比如 select 和 from 之间 的 就是 columnList Word , where 关键字 之后的 就是 where 条件 Word 。

接下来 就 进一步 解析 columnList Word 和 where 条件 Word 。

columnList Word 的 解析比较简单, 直接 Split(',') , 再 去掉 栏位名 外面的 中括号 。

where 条件 的 解析 由 ExpressParser 负责 。

Express(表达式) 的 解析 同样 是 先分词(Word) , 同样 也 先 根据 包裹符 分词 , 然后 在 未被包裹 的 Word 中 寻找 运算符 。

这是 第一遍 扫描 。

第二遍 扫描 则是 根据 运算符 来 分词(Word) ,运算符 两边 的 Word 又作为 Express(表达式) 再交给 ExpressParser 递归解析 。

SqlParser 负责 总体 的 解析 工作 。 包括 调用 Parser 和 ExpressParser , 以及 获取 ColumnList 和 寻找 KeyWord 。
ColumnList 是 select 关键字 后面 要 select 的 栏位列表 。

总体的 解析结果 是 返回 ColumnList 和 Express 对象嵌套 , 没有 生成 目标代码 。 如果 生成 目标代码 , 那就是 编译原理 了 。 呵呵

还好 C# 支持 dynamic 类型 。 不然 处理 不同数据 类型 之间 的 运算 会 搞死 。

就以 加法 为例 , 加法支持 int long float double decimal string 6 种 类型 。 其中 前 5 种 数值类型 是 可以互相 相加 的 。 那么 就要 判断 5 * 5 = 25 种 情况, 再 加上 string 的 2 种 情况 , 要 判断 27 种 情况 。 这还只是 加法 。 呵呵

文本解析 的 部分 没有用 正则表达式 。 而是 用 串操作 。 因为 我不会 正则表达式 。 正则表达式 难写 , 更难读 。 呵呵

项目 里 有一个 类 StrUtil , 可以 方便 的 进行 串操作 和 文本解析 。 ^^

SelectDataTable的更多相关文章

  1. 从零开始编写自己的C#框架(14)——T4模板在逻辑层中的应用(三)

    原本关于T4模板原想分5个章节详细解说的,不过因为最近比较忙,也不想将整个系列时间拉得太长,所以就将它们整合在一块了,可能会有很多细节没有讲到,希望大家自己对着代码与模板去研究. 本章代码量会比较大, ...

  2. SubSonic3.0插件分页查询速度测试

    使用SubSonic3.0一段时间了,一直都想找机会测试一下各种查询分页速度,对比一下插件的查询效率到底怎么样,所以昨天写好了测试程序,准备好1K.1W.10W.50W和100W记录的数据表,早上详细 ...

  3. Wijmo 日历插件

    说明: 因为项目(OA)的需要,我负责开发日程的模块,相信大家用过谷歌的日历了吧,是不是觉得挺好用,但又苦于无法实现? 这里告诉你一个很好的插件,Wijmo,而里面有一个类似谷歌的日历事件插件,真的很 ...

  4. 我发起了一个 .Net 开源 跨平台 GUI (界面开发框架)项目 HtmlCore

    大家好 , 我发起了一个 .Net 开源 跨平台 GUI (界面开发框架)项目 , 名字叫 HtmlCore  . 项目的一个主要目标是可以用 .Net 在 移动设备 上 开发 GUI 程序 (界面程 ...

  5. 我发起了一个 .Net 平台上的 NewSql 数据库 BabanaDB

    发起这个项目的起因, 是偶然看到一个网友发的 MongoDB 的 新闻, 我想, 像  MongoDB  这样的 非关系数据库 ,随时 都可以写 很多个, 真正 难写 的 是  关系数据库, 非关系数 ...

  6. 我发起并创立了一个 VMBC 的 子项目 D#

    大家好, 我发起并创立了一个 VMBC 的 子项目 D#  . 有关 VMBC ,  请参考 <我发起了一个 用 C 语言 作为 中间语言 的 编译器 项目 VMBC>     https ...

  7. 我发起了一个 .Net 平台上的 开源项目 知识图谱 Babana Map 和 文本文件搜索引擎 Babana Search

    起因 也是 前几天 有 网友 在 群 里发了   知识图谱   相关的文章, 还有 有 网友 问起   NLog -> LogStash -> Elastic Search  的 问题, ...

随机推荐

  1. springMVC拦截css与js等资源文件的解决

    写了一个demo的ssm,使用jetty容器跑的,但是在页面的时候总是发现访问资源出现404. 换了多种写法不见效. 偶然发现日志中请求被springMVC拦截了,气死我了. 解决方式: Spring ...

  2. synchronized 和 ReentrantLock 区别

    synchronized 使用: 1:当一个线程访问object的一个synchronized(this)同步代码块时,它就获得了这个object的对象锁.结果,其它线程对该object对象所有同步代 ...

  3. CHERRY G80 3000L 使用一月有感

    就是楼上这家伙.. 都说程序猿用的最多的除了自己的右手就是键盘了.- - SO一个好的键盘必定会令写码的速度提升. 在TB和JD上选择许久,在青轴,红轴,黑轴,茶轴间难以抉择. 最后终于敲定: CHE ...

  4. HDU 4704 Sum(隔板原理+组合数求和公式+费马小定理+快速幂)

    题目传送:http://acm.hdu.edu.cn/showproblem.php?pid=4704 Problem Description   Sample Input 2 Sample Outp ...

  5. 【Python】etree方法生成,解析xml

    #练习:另一种遍历xml文件的方式etree,xpathimport systry: import xml.etree.cElementTree as ET #前面带c的都是比较快的,效率高且不占内存 ...

  6. 【转】如何在win10(64位系统)上安装apache服务器

    如何在win10(64位系统)上安装apache服务器 今天装了Apache服务器,下面是我总结的方法: 一,准备软件 1.64位的apache版本 传送门:http://www.apacheloun ...

  7. insserv: warning: script 'busybox-httpd' missing LSB tags and overrides

    /********************************************************************************* * insserv: warnin ...

  8. 安卓与Unity交互之-Android Studio创建Module库模块教程

    安卓开发工具创建Module库 本文提供全流程,中文翻译. Chinar 坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 -- 高分辨率用户请根据需求调整网页缩放比例) Chinar -- 心分 ...

  9. 自定义bootbox:dialog方法

    <script src="static/ace/js/bootbox.js"></script>bootbox.dialog({ message: '< ...

  10. webpack的一些详细配置

    http://blog.csdn.net/c_kite/article/details/71279853