背景

  Orm用过一些,但处理增删改上面做的都不错。但是查询上跟我想要的效果总是差了一点。我想要的效果则是这样,基于某种命名规则进行传参,后台解析器知道命名规则即可知道它要查询什么样的数据。

  谈谈我之前的做法,比如说,页面将查询条件存入对象,序列化后后传递给控制器,此时控制器将其反序列化成Json,数据类型使用Dictionary<string,object>。里面存储的Key目前是这样的格式: BeginTime, EndTime, Age, LikeAddress , NullTel , UnLikeMM , 其中 Begin End Like UnLike Null 等是自定义的命名规则,告诉后台我需要查询的数据类型,具体的含义看前缀大致即可知道。如传入BeginTime=2013-10-31 21:55:47,希望得到时间大于这个值的数。

  当时后台则是尝试去判断每一个值,如使用 Dictionary.TryGetValue("BeginTime",out obj) , 来进行条件的传值判断。这个地方还存在一个类型问题,时间到了后台变成了时间字符串,而不是DateTime类型。此处则需要强制转换。也正式因为这些原因,代码写的不大工整,尽管做了一些封装,稍微简洁点,但还不是我要的效果。

  以此为主题,写了一个初步的实现,希望各位朋友能给出部分建议,如果有类似的成熟的框架,能让我在后台定义个SQL之后,前端只要传入规定的命名字段,即可完成查询,这样是再好不过了。

测试效果

            var strSql = "select * from Users where ";
var dic = new Dictionary<string, object>();
dic["BeginAge"] = "";//Age>=18
dic["EndAge"] = ;//Age<=80
dic["LikeName"] = "玲";//Name包含'玲'
dic["IsGirl"] = "true";//IsGirl = true
dic["BeginLoginTime"] = DateTime.Now.AddDays(-);//LoginTime >= 七天前
dic["EndLoginTime"] = DateTime.Now.ToString();//LoginTime <= 今天
//部分类型若不正确,则需要手动映射
SqlMapper mapper = new SqlMapper(dic);
mapper.LoadTypeMapper<DateTime>("LoginTime");
mapper.LoadTypeMapper<int>("Age");
mapper.LoadTypeMapper<bool>("IsGirl");
//看看生成的条件语句
var where = mapper.Where();
Console.WriteLine("{0} {1}", strSql, where);
Console.WriteLine();

  

  目前的效果则如图,得到对应的SQL语句,并且将数据类型转换正确。

  我们在看看复杂的查询。

            strSql = "select * from Table1 t1 inner join Table2 t2 on t1.ID=t2.Table1ID where ";
dic["t1.UserName"] = "admin";//UserName='admin'
dic["t1.BeginAge"] = ;//Age>=18
dic["t1.EndAge"] = "";//Age<=80
dic["t1.NullSex"] = "false";//Sex is not null
dic["t1.NullNice"] = "true";//Nice is true
dic["t2.LikeHomeName"] = "中国";//HomeName like '%中国%'
dic["t2.UnLikeAddress"] = "郊区";//Address not like '%郊区%'
dic["t2.BeginCreateTime"] = DateTime.Now.ToString();//CreateTime >= DateTime.Now
mapper = new SqlMapper(dic);
mapper.LoadTypeMapper<DateTime>("CreateTime");
mapper.LoadTypeMapper<int>("Age");
mapper.LoadTypeMapper<bool>("Sex");
where = mapper.Where();
Console.WriteLine("{0} {1}", strSql, where);
Console.WriteLine();
//看看格式化后的Dictionary
foreach (var e in dic)
{
Console.WriteLine("{0}:{1} {2}", e.Key, e.Value, e.Value.GetType());
}

    

    我想要的效果,大致就是这样,由于是测试代码,所以直接构造了Dictionary,并且写入了对应的数据(类型有正确有错误)。

    实现方式很简单,则是遍历Dictionary,根据命名规则定义的前缀,来拼接SQL语句,并且检测当前类型,如果是string类型,则需要和映射的类型匹配一下,不相同,则将string类型转换成Mapper中映射的类型。

    最后在重申一下我想达到的目的,后台定义SQL语句,如Select ....,方法接收Dictionary参数,解析后传递给ado或者orm去执行,如此一来,前端想查询什么样的数据,只需要定义条件就好了。

  测试代码下载

    

理想中的SQL语句条件拼接方式的更多相关文章

  1. 理想中的SQL语句条件拼接方式 (二)

    问题以及想要的效果,不重复叙述,如果需要的请先看 理想中的SQL语句条件拼接方式 . 效果 现在有2个类映射数据库的2张表,结构如下: public class User { public int U ...

  2. MyBatis中动态SQL语句完成多条件查询

    一看这标题,我都感觉到是mybatis在动态SQL语句中的多条件查询是多么的强大,不仅让我们用SQL语句完成了对数据库的操作:还通过一些条件选择语句让我们SQL的多条件.动态查询更加容易.简洁.直观. ...

  3. [转帖]关于Java中SQL语句的拼接规则

    关于Java中SQL语句的拼接规则 自学demo 的时候遇到的问题 结果应该是 '"+e.getName()+"' 注意 一共有三组标点符号 (除去 方法函数后面的括号) 实现目标 ...

  4. 在Excel中使用SQL语句查询和筛选

    本文转自:http://blog.sina.com.cn/s/blog_5fc375650102e1g5.html 今天在微博上看到@数据分析精选 分享的一篇文章,是关于<在Excel中使用SQ ...

  5. [转]在EntityFramework6中执行SQL语句

    本文转自:http://www.cnblogs.com/wujingtao/p/5412329.html 在上一节中我介绍了如何使用EF6对数据库实现CRDU以及事务,我们没有写一句SQL就完成了所有 ...

  6. sql语句分页多种方式ROW_NUMBER()OVER

    sql语句分页多种方式ROW_NUMBER()OVER 摘自: http://www.cnblogs.com/CodingArt/articles/1692468.html 方式一 select to ...

  7. 在EntityFramework6中执行SQL语句

    在EntityFramework6中执行SQL语句 在上一节中我介绍了如何使用EF6对数据库实现CRDU以及事务,我们没有写一句SQL就完成了所有操作.这一节我来介绍一下如何使用在EF6中执行SQL语 ...

  8. 在EF中执行SQL语句(转载)

    在EF中执行SQL语句   你可能要问,我用EF不就为了避免写SQL吗?如果要写SQL我不如直接用ADO.NET得了.话虽然这么说没错,可有些时候使用EF操作数据还是有一些不方便,例如让你根据条件删除 ...

  9. 在EntityFramework6中执行SQL语句【转】

    在上一节中我介绍了如何使用EF6对数据库实现CRDU以及事务,我们没有写一句SQL就完成了所有操作.这一节我来介绍一下如何使用在EF6中执行SQL语句. 你可能要问,我用EF不就为了避免写SQL吗?如 ...

随机推荐

  1. 中缀表达式转后缀表达式(Python实现)

    中缀表达式转后缀表达式 中缀表达式转后缀表达式的规则: 1.遇到操作数,直接输出: 2.栈为空时,遇到运算符,入栈: 3.遇到左括号,将其入栈: 4.遇到右括号,执行出栈操作,并将出栈的元素输出,直到 ...

  2. 寻找物体的凸包 opencv

    凸包的含义: 在二维平面上给定点集,凸包就是将最外层的点连接起来构成的凸多边形.并且这个凸多边形能包含点集中所有的点.OPENCV中: convexHull函数用于寻找图像点集中的凸包.它有六个输入参 ...

  3. MySQL触发器和更新操作

    一.触发器概念 触发器(trigger):监视某种情况,并触发某种操作,它是提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动 ...

  4. 牛客暑假多校第一场J-Different Integers

    一.题目描述: 链接:https://www.nowcoder.com/acm/contest/139/JGiven a sequence of integers a1, a2, ..., an an ...

  5. 笔记-mysql-管理及基础操作

    笔记-mysql使用-管理及基础操作 1.      简介 mysql是一个免费的关系型数据库,不过好像被oracle收购了.... 希望它继续免费. 1.1.    相关术语 数据库,表,列,行,冗 ...

  6. spark练习--统计xxx大学的各个少数名族的情况

    最近,有一份数据,是关于学校的数据,这个里面有所有学生的信息,今天闲来没事,我就想用spark的方式来读取文件,并且来统计这个学校的各个民族的情况,以前我用hadoop中mapReduce来计算,不得 ...

  7. elasticsearch安装教程

    目录 1 java8 环境 2 安装elasticsearch 3 安装kibana 4. 单服务器部署多个节点 参考: 1 java8 环境 elasticsearch需要安装java 8 环境,配 ...

  8. 用scrapy数据抓取实践

    本文来自网易云社区 作者:沈高峰 数据分析中需要用到的不少数据都是需要进行抓取的,并且需要对抓取的数据进行解析之后存入数据库.scrapy是一个强大的爬虫框架,本文简单介绍下使用scrapy进行垂直抓 ...

  9. android的5个进程等级

    一.Foreground Process(前台进程,优先级别最高) 1.正处于 Activity Resume() 状态 2.正处于与 bound 服务交互的状态 3.正处于服务在前台运行的状态(st ...

  10. maven常用命令 与语法

    pom.xml 中个元素的意义 groupId 规定了这个项目属于哪个组,或者公司之类的 artifactId 定义了当前maven项目在组中唯一的ID version 版本号 常用命令 mvn co ...