带有空TextBox的搜索页面返回 - 空或全文谓词

时间:2014-08-01 15:38:39

标签: c# sql asp.net

我在搜索页面上工作。我正在使用2个中继器。首先显示搜索结果,然后显示分页。

如果我排除回发,查询就可以了。我可以在搜索框中输入内容,它会出现在屏幕上。没有回发,问题是当我点击进入第二页时,我丢失了寻呼中继器。这意味着我无法回到第一页。

所以我需要这个回发才能工作。

问题是当页面首次加载文本框为空时,因此我收到以下错误:"空或全空谓词。"

如何绕过它?

这是我的代码:

protected void Page_Load(object sender, EventArgs e)
{
    if (!IsPostBack)
    {
        BindRpt();
    }
}
private void BindRpt()
{ 
    SqlConnection cn = new SqlConnection(ConfigurationManager.ConnectionStrings["blabla"].ConnectionString);
    SqlCommand cmd = new SqlCommand();
    cmd.Connection = cn;
    SqlDataAdapter adapter = new SqlDataAdapter(cmd);
    cmd.CommandText = "select Distinct Rank, columnA, columnB, columnC from FREETEXTTABLE (TABLE, columnA , '" + Search.Text + "'  ) S, TABLE C WHERE c.columnID = S.[KEY] order by Rank Desc";

    DataTable dt = new DataTable();
    adapter.SelectCommand = cmd;
    adapter.Fill(dt);

    PagedDataSource pgitems = new PagedDataSource();
    pgitems.DataSource = dt.DefaultView;
    pgitems.AllowPaging = true;

    pgitems.PageSize = 2;
    pgitems.CurrentPageIndex = PageNumber;
    if (pgitems.Count > 1)
    {
        rptPaging.Visible = true;
        ArrayList pages = new ArrayList();
        for (int i = 0; i <= pgitems.PageCount - 1; i++)
        {
            pages.Add((i + 1).ToString());
        }
        rptPaging.DataSource = pages;
        rptPaging.DataBind();
    }
    else 
    {
        rptPaging.Visible = false;
    }
    rptResults.DataSource = pgitems;
    rptResults.DataBind();
}
public int PageNumber
{ 
    get
    {
        if(ViewState["PageNumber"] != null)
        {
            return Convert.ToInt32(ViewState["PageNumber"]);
        }
        else
        {
            return 0;
        }
    }
    set 
    { ViewState["PageNumber"] = value; }
}
protected void rptPaging_ItemCommand(object source, System.Web.UI.WebControls.RepeaterCommandEventArgs e)
{
    PageNumber = Convert.ToInt32(e.CommandArgument) - 1;
    BindRpt();
}
protected void btnGo_Click(object sender, EventArgs e)
{
    BindRpt();
}

2 个答案:

答案 0 :(得分:1)

尝试添加以下内容作为BindRpt()的第一行

if (string.IsNullOrEmpty(Search.Text)) return;

答案 1 :(得分:0)

更新以下条件:

if (pgitems.Count > 1)

if (pgitems.Count > 0)