SqlDataSource 中 参数动态赋值的方法

第一种情况:查询条件是固定的

下面以SelectCommand为例进行说明
创建的SqlDataSource如下:

  < asp:SqlDataSource ID = " SqlDataSource1 "  runat = " server "  ConnectionString = " <%$ ConnectionStrings:WHGDTempConnectionString %> "
            SelectCommand
= " SELECT [ID], [TVNum], [HostName], [TerminalNum], [Addr] FROM [AddrInfo] WHERE ([ID] = @ID) " >
            
< SelectParameters >
                
< asp:Parameter DefaultValue = " 1 "  Name = " ID "  Type = " Decimal "   />
            
</ SelectParameters >
        
</ asp:SqlDataSource >

在程序中运行时给ID参数赋值如下:
this.SqlDataSource1.SelectParameters["ID"].DefaultValue = "2";//这个就是给参数的赋值语句
 this.SqlDataSource1.DataBind();
 this.GridView1.DataBind();

 

第二种情况:查询条件是随机变化的,动态增减;这时需要在后台构造Sqldatasource的selectcommand。这种情况下需要如下操作:

        第一步:清空SqlDataSource的SelectParameters

this.SqlDataSource1.SelectParameters.Clear();

       第二步:构造SelectCommand,并给selectparameters增加参数并赋值

 

string Sqlstr =  " SELECT * FROM [butabel] WHERE  ";
  if (TextBox2.Text !=  "" && TextBox2.Text.Trim() !=  "")
    {
       Sqlstr = Sqlstr +  "  ([circuitvB] LIKE '%' + @circuitvB + '%') and  ";
     // 下面这是给Sqldatasource增加 SelectParameters参数并赋值    
   this.SqlDataSource1.SelectParameters.Add("circuitvB", System.TypeCode.String, TextBox2.Text.Trim());
        }

   后记:如果涉及到Gridview的分页、排序、编辑需要给相应的函数中添加查询函数。例如:

           protected void GridView1_PageIndexChanging1(object sender, GridViewPageEventArgs e) { searchFuc(); }

           protected void GridView1_Sorting(object sender, GridViewSortEventArgs e) { searchFuc();}

           protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e) {  searchFuc();}

           protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e) { searchFuc();}

           protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e)  {searchFuc();}
           protected void GridView1_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e) { searchFuc(); }


 

转载于:https://www.cnblogs.com/qqingmu/archive/2008/01/08/1031013.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值