列表查询组件代码, 简化拼接条件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

posted on   伍华聪  阅读(8516)  评论(23编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)

导航

< 2007年11月 >
28 29 30 31 1 2 3
4 5 6 7 8 9 10
11 12 13 14 15 16 17
18 19 20 21 22 23 24
25 26 27 28 29 30 1
2 3 4 5 6 7 8
点击右上角即可分享
微信分享提示