zoukankan      html  css  js  c++  java
  • 列表查询组件代码, 简化拼接条件SQL语句的麻烦

    控件代码及测试例子:https://files.cnblogs.com/wuhuacong/CommonSearch.rar 

    使用场景:
    在列表页面中,一般有好几个条件, 用户进行查询时候,需要根据这几个条件进行过滤查询.但在组装这些过滤条件的时候,代码比较烦琐臃肿,本组件代码为解决该问题而设计。

    使用目的:  1.减少对参数非空的条件判断 2. 可以构造出参数化的DbCommand对象,简化操作. 3.适当修改后可以用于其他数据访问的参数化参数生成.4.构造Sql语句或者参数化条件更加易读


    1. 生成SQL条件语句
    如有几个字段,需要根据不同的字段进行过滤,想生成的SQL语句如下:
     Where (1=1)  AND AA2  Like  '%AA2Value%' AND AA6  >=  'Value6' AND AA7  <=  'value7' AND AA3  =  'Value3' AND AA4  <  'Value4' AND AA5  >  'Value5' AND AA  <>  '1'
     
    那么代码如下:

                SearchCondition search = new SearchCondition();
                search.AddCondition(
    "AA"1, SqlOperator.NotEqual)
                    .AddCondition(
    "AA2""AA2Value", SqlOperator.Like)
                    .AddCondition(
    "AA3""Value3", SqlOperator.Equal)
                    .AddCondition(
    "AA4""Value4", SqlOperator.LessThan)
                    .AddCondition(
    "AA5""Value5", SqlOperator.MoreThan)
                    .AddCondition(
    "AA6""Value6", SqlOperator.MoreThanOrEqual)
                    .AddCondition(
    "AA7""value7", SqlOperator.LessThanOrEqual);
                
    string conditionSql = search.BuildConditionSql();


    2. 生成基于Enterprise Library的DbCommand对象

                Database db = DatabaseFactory.CreateDatabase();
                SearchCondition search 
    = new SearchCondition();
                search.AddCondition(
    "Name""测试" , SqlOperator.Like)
                      .AddCondition(
    "ID"1, SqlOperator.MoreThanOrEqual);
                DbCommand dbComand  
    = search.BuildDbCommand(db, "select Comments from Test"" Order by Name");
                
    using (IDataReader dr = db.ExecuteReader(dbComand))
                
    {
                    
    while (dr.Read())
                    
    {
                        
    this.txtSql.Text += "\r\n" + dr["Comments"].ToString();
                    }

                }


    下面是该控件的类对象图解
    Search.jpg

    下面我们比较一下使用该控件和不使用在列表查询页面中的代码,可以看出使用了控件后的代码大大较少了,并且可读性也增强了

    1. 使用该控件, 列表查询页面中的代码

        private string GetCondition()
        
    {
            SearchCondition search 
    = new SearchCondition();
            search.AddCondition(
    "GroupID"this.ddlUserGroup.SelectedValue, SqlOperator.Equal, true)//班组ID
                  .AddCondition("DealGroupName"this.ddlDealGroup.SelectedValue, SqlOperator.Equal, true)/*消缺单位*/
                  .AddCondition(
    "VisioStationID"this.ddlStation.SelectedValue, SqlOperator.Like, true)//变电站
                  .AddCondition("VisioImageID"this.ddlLine.SelectedValue, SqlOperator.Like, true)/*馈线*/
                  .AddCondition(
    "BugNo"this.txtBugNo.Text.Trim(), SqlOperator.Like, true)/*编号*/
                  .AddCondition(
    "Finder"this.ddlFindUser.SelectedValue, SqlOperator.Like, true)/*发现人*/
                  .AddCondition(
    "CheckUser"this.ddlCheckUser.SelectedValue, SqlOperator.Like, true)//验收人
                  .AddCondition("DeviceBug.BugType"this.ddlBugType.SelectedValue, SqlOperator.Equal, true)//缺陷类别
                  .AddCondition("CurrentState"this.ddlCurrentState.SelectedValue, SqlOperator.Equal, true)//处理状态
                  .AddCondition("FindDate"this.txtFindBeginDate.Text.Trim(), SqlOperator.MoreThanOrEqual, true)//发现日期
                  .AddCondition("FindDate"this.txtFindEndDate.Text.Trim(), SqlOperator.LessThanOrEqual, true)//发现日期
                  .AddCondition("EndDate"this.txtEndBeginDate.Text.Trim(), SqlOperator.MoreThanOrEqual, true)//消缺日期
                  .AddCondition("EndDate"this.txtEndEndDate.Text.Trim(), SqlOperator.LessThanOrEqual, true);//消缺日期

            
    return search.BuildConditionSql();
        }

    2. 普通做法,不使用控件,列表查询页面中的代码
    Code
    主要研究技术:代码生成工具、会员管理系统、客户关系管理软件、病人资料管理软件、Visio二次开发、酒店管理系统、仓库管理系统等共享软件开发
    专注于Winform开发框架/混合式开发框架Web开发框架Bootstrap开发框架微信门户开发框架的研究及应用
      转载请注明出处:
    撰写人:伍华聪  http://www.iqidi.com 
        
  • 相关阅读:
    JSP中的一个树型结构
    访问SAP的RFC
    MySQL InnoDB的一些参数说明
    Python: 去掉字符串中的非数字(或非字母)字符
    获取百度地图代码方法
    ps修图之——四步去修图后的毛边
    Python中给文件加锁
    问答项目---金币经验奖励规则及网站配置写入config文件
    问答项目---封装打印数组的方法
    问答项目---栏目增删改方法示例
  • 原文地址:https://www.cnblogs.com/wuhuacong/p/964100.html
Copyright © 2011-2022 走看看