SqlDataSource中参数动态赋值的方法

发布时间:2017-09-21编辑:佚名阅读(2071)

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


下面以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(); }


    关键字: SqlDataSource 参数 动态赋值


鼓掌

0

正能量

0

0

呵呵

0


评论区