上篇文章发布了一些设计orm框架基层的和实现,有朋友提出WhereHelper是亮点,能被认可我表示高兴.

我就把WhereHelper设计思想和代码公开下.

WhereHelper 的概念就是再拼接where 条件,为了能兼容各种数据库和参数化查询,故封装了该对象.

首先根据我的框架结构:

  1.Common库

    这里主要定义了,所有层都访问的类型及常用方法,因为是介绍WhereHelper的实现,对其它就不做详细解释了.

WhereHelper定义到这一层是想着UI会用到该查询,故把该类型的定义放到Common里

  2.DataAccess

    该层是操作数据库的一些方法封装.

在Common里的WhereHelper它是抽象的(其实完全可以是接口),且构造函数为

WhereHelper的实现类均放在DataAccess里,而且它的实现类构造函数都为 internal ,这个是为了实现只有我的Dal具体类(SQLDalBase,OracleDalBase,等等)知道它应该创建什么类型的具体WhereHelper对象,其实在DalBase里定义了WHereHelper的工厂.

不能让调用者直接创建.否则整个系统改变数据库时,就意味着要改变它创建的具体对象.

以下是WHereHelper的代码具体实现

public abstract class WhereHelper
{
#region 构造函数 protected WhereHelper()
{
_WhereText = new StringBuilder();
_ParamDict = new Dictionary<string, object>();
}
protected WhereHelper(string paramNameKey)
: this()
{
_ParamNameKey = paramNameKey;
}
protected WhereHelper(WhereHelper wh)
: this()
{
this._LastParamIndex = wh._LastParamIndex;
this._ParamDict = wh._ParamDict;
this._WhereText = wh._WhereText;
this._ParamNameKey = wh._ParamNameKey;
} #endregion #region 重写ToString public override string ToString()
{
return _WhereText.ToString();
} #endregion #region 字段 string _ParamNameKey;
StringBuilder _WhereText;
Dictionary<string, object> _ParamDict;
int _LastParamIndex = -; #endregion #region 属性 /// <summary>
/// 返回当前对象所有产品参数集合字典,key:参数数名(包含@),value:参数值
/// </summary>
public Dictionary<string, object> ParamDict
{
get
{
return _ParamDict;
}
}
/// <summary>
/// 返回当前生成where文本
/// </summary>
public StringBuilder WhereText
{
get
{
return _WhereText;
}
} #endregion #region 外部方法 /// <summary>
/// 增加查询参数,并输出参数名,参数名会根据LastParamIndex递增
/// </summary>
/// <param name="v">参数值</param>
/// <returns>返回参数名</returns>
protected string AddParam(object v)
{
_LastParamIndex++;
string paramName = string.Format("@P_{1}{0}", _LastParamIndex, _ParamNameKey);
_ParamDict.Add(paramName, v);
return paramName;
}
/// <summary>
/// 清除文本内容和参数内容
/// </summary>
public void Clear()
{
_ParamDict.Clear();
_WhereText.Remove(, _WhereText.Length);
}
/// <summary>
/// 当前where文本增加字符(通常该值是 字段名 ),返回当前对象
/// </summary>
public virtual WhereHelper Add(string str)
{
this._WhereText.AppendFormat(" {0} ", str);
return this;
}
/// <summary>
/// 比较符,等于 "="
/// </summary>
public virtual WhereHelper Equal(object v)
{
this._WhereText.AppendFormat(" = {0}", AddParam(v));
return this;
}
/// <summary>
/// 比较符,不等于 "!="
/// </summary>
public virtual WhereHelper EqualNot(object v)
{
_WhereText.AppendFormat(" <> {0}", AddParam(v));
return this;
}
/// <summary>
/// 比较符,大于 ">"
/// </summary>
public virtual WhereHelper GreaterThan(object v)
{
this._WhereText.AppendFormat(" > {0}", AddParam(v));
return this;
}
/// <summary>
/// 比较符,小于
/// </summary>
public virtual WhereHelper LessThan(object v)
{
this._WhereText.AppendFormat(" < {0}", this.AddParam(v));
return this;
}
/// <summary>
/// 比较符,大于等于
/// </summary>
public virtual WhereHelper GreaterThenEqual(object v)
{
this._WhereText.AppendFormat(" >= {0}", this.AddParam(v));
return this;
}
/// <summary>
/// 比较符,小于等于
/// </summary>
public virtual WhereHelper LessThanEqual(object v)
{
this._WhereText.AppendFormat(" <= {0}", this.AddParam(v));
return this;
}
/// <summary>
/// 比较符,In,参数为某范围内的比较值
/// </summary>
public virtual WhereHelper In(params object[] inArgs)
{
this._WhereText.Append(" in (");
for (int i = ; i < inArgs.Length; i++)
{
_WhereText.Append(AddParam(inArgs[i]));
if (i < inArgs.Length - )
{
_WhereText.Append(",");
}
}
this._WhereText.Append(" )");
return this;
}
/// <summary>
/// 比较符,NotIn
/// </summary>
public virtual WhereHelper NotIn(params object[] inArgs)
{
this._WhereText.Append(" not in (");
for (int i = ; i < inArgs.Length; i++)
{
_WhereText.Append(AddParam(inArgs[i]));
if (i < inArgs.Length - )
{
_WhereText.Append(",");
}
}
this._WhereText.Append(" )");
return this;
}
/// <summary>
/// 比较符 left Like %{0}
/// </summary>
public virtual WhereHelper LikeLeft(string v)
{
string addParam = AddParam(string.Format("%{0}", v));
this._WhereText.AppendFormat(" like {0}", addParam);
return this;
}
/// <summary>
/// 比较符 right like {0}%
/// </summary>
public virtual WhereHelper LikeRight(string v)
{
string addParam = AddParam(string.Format("{0}%", v));
this._WhereText.AppendFormat(" like {0}", addParam);
return this;
}
/// <summary>
/// 比较符 full like
/// </summary>
public virtual WhereHelper LikeFull(string v)
{
string addParam = AddParam(string.Format("%{0}%", v));
this._WhereText.AppendFormat(" like {0}", addParam);
return this;
}
/// <summary>
/// 增加一个左括号 "("
/// </summary>
public virtual WhereHelper BracketLeft()
{
this._WhereText.AppendFormat("(");
return this;
}
/// <summary>
/// 增加一个左括号"(",再加一个字符串(通常是一个字段)
/// </summary>
public virtual WhereHelper BracketLeft(string str)
{
this._WhereText.AppendFormat("(");
this._WhereText.AppendFormat(str);
return this;
}
/// <summary>
/// 增加一个右括号 ")"
/// </summary>
public virtual WhereHelper BracketRight()
{
this._WhereText.Append(")");
return this;
}
/// <summary>
/// 增加连接符 "and"
/// </summary>
public virtual WhereHelper And()
{
And(string.Empty);
return this;
}
/// <summary>
/// 增加连接符 "and"
/// </summary>
public virtual WhereHelper And(string str)
{
if (this._WhereText.Length > )
{
this._WhereText.Append(" and ");
}
this._WhereText.Append(str);
return this;
}
/// <summary>
/// 增加连接符 "or"
/// </summary>
public virtual WhereHelper Or()
{
Or(string.Empty);
return this;
}
/// <summary>
/// 增加连接符"or",再加一个字符串(通常是一个字段)
/// </summary>
public virtual WhereHelper Or(string str)
{
if (this._WhereText.Length > )
{
this._WhereText.Append(" or ");
}
this._WhereText.Append(str);
return this;
} #endregion
}

代码实现比较简单.

这个抽象类有了具体实现,如果再使用非sqlserver数据库时报错了(sql语法),那么就去DataAccess中找到它对应的具体类,去重写它的方法.

该类的所有public方法都返回了 this,也就是说,你"点"把它始终是一个对象.

拼接方式也非常灵活,可以直接拼写sql文(但不建议)它会给迁移数据库带来隐患.

至于参数的名字,只要你是一个WHereHleper对象,它是肯定不会重复的,如果你要拼接另外一个未知的WHereHelper到当前对象你可以用它的另一个构造(用到的几率很小)

举个例子吧:

  sql where条件:  姓名='张三'   and 年龄 > 20 and 年龄<30 and (性别=男 or 性别=女 )

代码如下:

WhereHelper wh1 = _BllObj.CreateWhereHelper();
wh1.Add("姓名")
.Equal("张三")
.And("年龄")
.GreaterThan()
.And("年龄")
.LessThan()
.And()
.BracketLeft("性别")
.Equal("男")
.Or("性别")
.BracketRight();

为了格式好看,我把它每次"点"分成了一行(这个看起来确实有点像jquery的感觉);

好了,这个实现大概先说这么多,如果有什么问题欢迎留言.

有人回复,我才有写下去的动力.

关于我的orm框架,第一篇,其实是实现的根本.

值的写出来或许还有DBHelper的实现,通常初学者都会写一个具体的如:SQL Server 数据的 SQLHelper ,当你写另外一个数据库支持的时候就会发现你的重复代码很多,就会想起我们亲爱的"面向对象"了.

c# 轻量级ORM框架 之 WhereHelper (二)的更多相关文章

  1. 轻量级ORM框架Dapper应用二:使用Dapper实现CURD操作

    在上一篇文章中,讲解了如何安装Dapper,这篇文章中将会讲解如何使用Dapper使用CURD操作. 例子中使用到的实体类定义如下: using System; using System.Collec ...

  2. c# 轻量级ORM框架 实现(一)

    发布一个自己写的一个轻量级ORM框架,本框架设计期初基于三层架构.所以从命名上来看,了解三层的朋友会很好理解. 设计该框架的目的:不想重复的写增删改查,把精力放到功能实现上. 发布改框架的原因:希望给 ...

  3. 轻量级ORM框架 QX_Frame.Bantina(二、框架使用方式介绍)

    轻量级ORM框架QX_Frame.Bantina系列讲解(开源) 一.框架简介 http://www.cnblogs.com/qixiaoyizhan/p/7417467.html 二.框架使用方式介 ...

  4. 轻量级ORM框架初探-Dapper与PetaPoco的基本使用

    一.EntityFramework EF是传统的ORM框架,也是一个比较重量级的ORM框架.这里仍然使用EF的原因在于为了突出轻量级ORM框架的性能,所谓有对比才有更优的选择. 1.1 准备一张数据库 ...

  5. 轻量级ORM框架 QX_Frame.Bantina(一、框架简介)

    轻量级ORM框架QX_Frame.Bantina系列讲解(开源) 一.框架简介 http://www.cnblogs.com/qixiaoyizhan/p/7417467.html 二.框架使用方式介 ...

  6. .NET轻量级ORM框架Dapper入门精通

    一.课程介绍 本次分享课程包含两个部分<.NET轻量级ORM框架Dapper修炼手册>和<.NET轻量级ORM框架Dapper葵花宝典>,阿笨将带领大家一起领略轻量级ORM框架 ...

  7. 轻量级ORM框架Dapper应用一:Dapper安装

    一.Dapper简介 Dapper是一款轻量级ORM框架,为解决网站访问流量极高而产生的性能问题而构造,主要通过执行TSQL表达式而实现数据库的CQRS. 如果你在项目中遇到性能访问问题,选择Dapp ...

  8. C# 性能优化 之 秒表 Stopwatch。 Dapper一个和petapoco差不多的轻量级ORM框架

    Sweet小马 小马同学的编程日记. C# 性能优化 之 秒表 Stopwatch. 生词解释:Diagnostics[,daɪəg'nɑstɪks] n.诊断学 using System.Diagn ...

  9. 分享自己写的基于Dapper的轻量级ORM框架~

    1.说明 本项目是一个使用.NET Standard 2.0开发的,基于 Dapper 的轻量级 ORM 框架,包含基本的CRUD以及根据表达式进行一些操作的方法,目前只针对单表,不包含多表连接操作. ...

随机推荐

  1. api-ms-win-crt-runtime-l1-1-0.dll丢失问题

    笔者是在安装python 3.5 后,启动时提示该文件丢失的问题的,如下所示.

  2. JVM内存结构之三--持久代

    本文会介绍一些JVM内存结构的基本概念,然后很快会讲到持久代,来看下Java SE 8发布后它究竟到哪去了. 基础知识 JVM只不过是运行在你系统上的另一个进程而已,这一切的魔法始于一个java命令. ...

  3. yii框架AR详解

    虽 然Yii DAO可以处理事实上任何数据库相关的任务,但很可能我们会花费90%的时间用来编写一些通用的SQL语句来执行CRUD操作(创建,读取,更新和删除). 同时我们也很难维护这些PHP和SQL语 ...

  4. iOS学习笔记之ARC内存管理

    iOS学习笔记之ARC内存管理 写在前面 ARC(Automatic Reference Counting),自动引用计数,是iOS中采用的一种内存管理方式. 指针变量与对象所有权 指针变量暗含了对其 ...

  5. MapReduce 中job.setJarByClass()方法的疑惑

    在调试mr实例的时候,遇到如下的情况,如图所示 说明:就是我的mr程序类名称和我设置的setJarByclass()中设置的不一样,但是程序竟然没有报错!!!!当时把我吓尿了 疑惑:如果这样设置的话, ...

  6. Monitor traffic to localhost from IE or .NET

    原文:http://docs.telerik.com/fiddler/Configure-Fiddler/Tasks/MonitorLocalTraffic Monitor traffic to lo ...

  7. 笔记:C语言数据类型在32位与64位机器上的字节数

    读<深入理解计算机系统> 第二章 信息的表示与处理 32位与64位的典型值,单位字节 声明 32位机器 64位机器 char 1 1 short int int 4 4 long int ...

  8. Linux securecrt破解

    其实,以前接触过破解的东西,但是很多东西早就忘记了,何况是在Linux环境下. 结果我常识更改时间,哦,不是更改日期,往后推4天,结果显示了26 days remaining. 所以完全可以更改日期来 ...

  9. Spark RDD概念学习系列之RDD是什么?(四)

       RDD是什么? 通俗地理解,RDD可以被抽象地理解为一个大的数组(Array),但是这个数组是分布在集群上的.详细见  Spark的数据存储 Spark的核心数据模型是RDD,但RDD是个抽象类 ...

  10. Win7 SP1语言包微软官方下载地址及使用方法 2

    情形一:如果您的系统版本是企业版.旗舰版,可以在Windows update中检测语言包按照提示下载安装即可.如果觉得Windows update不方便的话,可以在本文第二部分中下载所需的语言包,下载 ...