码迷,mamicode.com
首页 > 移动开发 > 详细

Dapper 封装01-操作符枚举

时间:2020-07-26 19:17:28      阅读:86      评论:0      收藏:0      [点我收藏+]

标签:stat   大于   query   empty   var   style   模糊   his   null   

目前我操作数据库主要用 EF和Dapper,EF不用说。相关的orm api 我们使用的很舒服,但是每次写Dapper 的时候我总是要写一坨SQL语句。典型的比如我要做一个查询。可能会写出一下代码:

var strText=""
if(string.IsNullOrEmpty(name))
{
   strText="AND NAME LIKE ‘%name%‘";  
}
if(age>0)
{
   strText=$"AND AGE={age}";  
}

所以也方便自己写一个相关的api,在工作里使用方便一点。

数据库操作符:= > < <> like between and or not (is null) (is not null)  >=  <=  所以我定义了一下枚举。

 public enum QueryOper
    {
        /// <summary>
        /// 等于
        /// </summary>
        Eq,
        /// <summary>
        /// 不等于
        /// </summary>
        NotEq,
        /// <summary>
        /// 大于
        /// </summary>
        Gt,
        /// <summary>
        /// 小于
        /// </summary>
        Lt,
        /// <summary>
        /// 大于或等于
        /// </summary>
        Ge,
        /// <summary>
        /// 小于或等于
        /// </summary>
        Le,
        /// <summary>
        /// 左右模糊匹配
        /// </summary>
        Like,
        /// <summary>
        /// 为空
        /// </summary>
        IsNull,
        /// <summary>
        /// 不为空
        /// </summary>
        IsNotNull,
        /// <summary>
        /// 区间
        /// </summary>
        Between
    }

这些枚举最后会转为相应的 数据库操作符。

    public static string ToString(QueryOper op)
        {
            switch (op)
            {
                case QueryOper.Eq:
                    return " = ";
                case QueryOper.NotEq:
                    return " <> ";  
                case QueryOper.Gt:
                    return " > ";
                case QueryOper.Lt:
                    return " < ";
                case QueryOper.Ge:
                    return " >= ";
                case QueryOper.Le:
                    return " <= ";
                case QueryOper.Like:
                    return " LIKE ";
                case QueryOper.IsNull:
                    return " IS NULL ";
                case QueryOper.IsNotNull:
                    return " IS NOT NULL ";
                case QueryOper.Between:
                    return " BETWEEN ";
                default:
                    throw new Exception("This method is not supported.");
            }
        }

 

Dapper 封装01-操作符枚举

标签:stat   大于   query   empty   var   style   模糊   his   null   

原文地址:https://www.cnblogs.com/delaywu/p/13380127.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!