列表查询组件代码, 简化拼接条件SQL语句的麻烦

控件代码及测试例子:http://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();
                }
            }

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

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

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. 普通做法,不使用控件,列表查询页面中的代码


        private string GetCondition()
        {
            string condition = "";
            if ( this.ddlUserGroup.SelectedValue != "0")
            {
                condition += string.Format( " GroupID = {0}" , this.ddlUserGroup.SelectedValue.ToString() );
            }

            //消缺单位
            if ( this.ddlDealGroup.SelectedValue != "0")
            {
                if (condition == "")
                {
                    condition += string.Format( " DealGroupName = '{0}'" , this.ddlDealGroup.SelectedItem.Text );
                }
                else
                {
                    condition += string.Format( " And DealGroupName = '{0}'" , this.ddlDealGroup.SelectedItem.Text );
                }
            }

            
            if (this.txtStation.Text.Trim() != "")
            {
                if (condition == "")
                {
                    condition += string.Format(" Station like '%{0}%'",this.txtStation.Text.Trim() );
                }
                else
                {
                    condition += string.Format(" And Station like '%{0}%' ",this.txtStation.Text.Trim() );
                }
            }

            if (this.txtLineName.Text.Trim() != "")
            {                
                if (condition == "")
                {
                    condition += string.Format(" LineName like '%{0}%'",this.txtLineName.Text.Trim() );
                }
                else
                {
                    condition += string.Format(" And LineName like '%{0}%' ",this.txtLineName.Text.Trim() );
                }
            }

            //编号
            if (this.txtBugNo.Text.Trim() != "")
            {
                if (condition == "")
                {
                    condition += string.Format("BugNo like '%{0}%'",this.txtBugNo.Text.Trim() );
                }
                else
                {
                    condition += string.Format(" And BugNo like '%{0}%'",this.txtBugNo.Text.Trim() );
                }
            }

            //发现人
            if ( ddlFindUser.SelectedIndex >= 1 )
            {
                if (condition == "")
                {
                    condition += string.Format("Finder like '%{0}%'",ddlFindUser.SelectedValue  );
                }
                else
                {
                    condition += string.Format(" And Finder like '%{0}%'",ddlFindUser.SelectedValue );
                }
            }

            //验收人
            if ( this.ddlCheckUser.SelectedIndex >= 1 )
            {
                if (condition == "")
                {
                    condition += string.Format("CheckUser like '%{0}%'",this.ddlCheckUser.SelectedValue );
                }
                else
                {
                    condition += string.Format(" And CheckUser like '%{0}%'",this.ddlCheckUser.SelectedValue );
                }
            }

            //缺陷类别
            if (this.ddlBugType.SelectedValue.Trim() != "#")
            {
                if (condition == "")
                {
                    condition += string.Format("DeviceBug.BugType={0}",this.ddlBugType.SelectedValue.Trim() );
                }
                else
                {
                    condition += string.Format(" And DeviceBug.BugType={0}",this.ddlBugType.SelectedValue.Trim() );
                }
            }
            
            //处理状态
            if (this.ddlCurrentState.SelectedValue.Trim() != "#")
            {
                if (condition == "")
                {
                    condition += string.Format("CurrentState='{0}'",this.ddlCurrentState.SelectedValue.Trim() );
                }
                else
                {
                    condition += string.Format(" And CurrentState='{0}'",this.ddlCurrentState.SelectedValue.Trim() );
                }
            }

            //发现日期
            if (this.txtFindBeginDate.Text.Trim() != "")
            {
                if (condition == "")
                {
                    condition += string.Format("FindDate>='{0}'",this.txtFindBeginDate.Text.Trim() );
                }
                else
                {
                    condition += string.Format(" And FindDate>='{0}'",this.txtFindBeginDate.Text.Trim() );
                }
            }
            if (this.txtFindEndDate.Text.Trim() != "")
            {
                if (condition == "")
                {
                    condition += string.Format("FindDate<='{0}'",this.txtFindEndDate.Text.Trim() );
                }
                else
                {
                    condition += string.Format(" And FindDate<='{0}'",this.txtFindEndDate.Text.Trim() );
                }
            }

            //消缺日期
            if (this.txtEndBeginDate.Text.Trim() != "")
            {
                if (condition == "")
                {
                    condition += string.Format("EndDate>='{0}'",this.txtEndBeginDate.Text.Trim() );
                }
                else
                {
                    condition += string.Format(" And EndDate>='{0}'",this.txtEndBeginDate.Text.Trim() );
                }
            }
            if (this.txtEndEndDate.Text.Trim() != "")
            {
                if (condition == "")
                {
                    condition += string.Format("EndDate<='{0}'",this.txtEndEndDate.Text.Trim() );
                }
                else
                {
                    condition += string.Format(" And EndDate<='{0}'",this.txtEndEndDate.Text.Trim() );
                }
            }
            return condition;        
        }

本文转自博客园伍华聪的博客,原文链接:列表查询组件代码, 简化拼接条件SQL语句的麻烦,如需转载请自行联系原博主。

时间: 2024-10-30 23:02:16

列表查询组件代码, 简化拼接条件SQL语句的麻烦的相关文章

thinkphp中多表查询中防止数据重复的sql语句(必看)_php技巧

下面先来看看例子: table id name 1 a 2 b 3 c 4 c 5 b 库结构大概这样,这只是一个简单的例子,实际情况会复杂得多. select *, count(distinct name) from table group by name 结果: id name count(distinct name) 1 a 1 2 b 1 3 c 1 最后一 项是多余的,不用管就行了 tp2.0手册   搜索连贯操作 可看到相关的资料 SELECT cat_id, COUNT(*) AS

注解-如何获取这个代码最终执行的SQL语句?

问题描述 如何获取这个代码最终执行的SQL语句? JAVA @Select("SELECT NAME FROM TABLE T WHERE T.FOCUS_ID=#{focusId} AND T.PROS_ID=#{prosupId}") public Bypass queryBypass(@Param("focusId") Integer focusId,@Param("prosupId") Integer prosupId); 在这种执行SQ

查询及删除重复记录的SQL语句

查询及删除重复记录的sql语句 (一) 比方说 在a表中存在一个字段"name", 而且不同记录之间的"name"值有可能会相同, 现在就是需要查询出在该表中的各记录之间,"name"值存在重复的项: select name,count(*) from a group by name having count(*) > 1 如果还查性别也相同大则如下: select name,sex,count(*) from a group by nam

优化SQL查询:如何写出高性能SQL语句

1. 首先要搞明白什么叫执行计划? 执行计划是数据库根据SQL语句和相关表的统计信息作出的一个查询方案,这个方案是由查询优化器自动分析产生的,比如一条SQL语句如果用来从一个 10万条记录的表中查1条记录,那查询优化器会选择"索引查找"方式,如果该表进行了归档,当前只剩下5000条记录了,那查询优化器就会改变方案,采用 "全表扫描"方式. 可见,执行计划并不是固定的,它是"个性化的".产生一个正确的"执行计划"有两点很重要:

oracle中复合索引的创建剖析—包含in的三个条件SQL语句复合索引的创建

之前文章中提过复合索引的创建思路: 1 前导列尽可能让更多的核心业务SQL能够使用 2 单个SQL语句索引的前导列尽量选择等值条件做为索引的前导列 这里我们如果在对in的谓词.三个条件的SQL语句复合索引的创建做一些更深入的分析,详细的例子如下: SQL> select * from v$version; BANNER -------------------------------------------------------------------------------- Oracle D

MyBatis MapperProvider MessageFormat拼接批量SQL语句执行报错的原因分析及解决办法_MsSql

最近在项目中有这么一段代码:下载服务器基础业务数据进行本地批量插入操作,因项目中使用mybatis进行持久化操作,故直接考虑使用mybatis的批量插入功能. 1.以下是Mapper接口的部分代码 public interface PrintMapper { @InsertProvider(type = PrintMapperProvider.class,method = "insertAllLotWithVehicleCode4H2") void insertAllLotWithVe

从500万条数据中查询,求优化一条SQL语句

问题描述 表结构如下,里面有500W数据.我没有权限修改这个表,所以请大家给我优化下SQL查询CREATE TABLE IF NOT EXISTS `jdp_tb_trade` ( `tid` bigint(20) NOT NULL, `status` varchar(64) DEFAULT NULL, `type` varchar(64) DEFAULT NULL, `seller_nick` varchar(32) DEFAULT NULL, `buyer_nick` varchar(32)

mysql查询在某个时间内的数据sql语句

比如我这边查询jz_user表用户创建时间大于四月一号到四月三十号为例  代码如下 复制代码 select FROM_UNIXTIME(create_time),user_id from jz_user Where DATE_FORMAT(FROM_UNIXTIME(create_time),'%Y-%m-%d') <= DATE_FORMAT("2013-4-30",'%Y-%m-%d') AND DATE_FORMAT(FROM_UNIXTIME(create_time),'

MYSQL 多表查询、删除、更新一些sql语句

例  代码如下 复制代码 SELECT cat.`name` , class.`title` FROM `cat` , `class` WHERE cat.`id` = class.`cat` AND cat.`id` =2 LIMIT 0 , 30 DELETE cat, class FROM cat, class WHERE cat.`id`=class.`cat` AND cat.`id`=1 多表更新在 MySQL 3.23 中,你可以使用 LIMIT # 来确保只有给定的记录行数目被更