具有空文本框的搜索页面返回-空或空全文谓词

本文关键字:文谓词 谓词 文本 搜索 返回 | 更新日期: 2023-09-27 18:16:04

我在一个搜索页面工作。我用了2个中继器。第一个显示搜索结果,第二个显示分页。

如果我排除回发,查询工作得很好。我可以在搜索框里输入一些东西,它就会出现在屏幕上。如果没有回发,问题是当我单击转到第二个页面时,我失去了分页中继器。这意味着我不能回到第一页。

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

问题是当页面第一次加载文本框是空的,因此我得到以下错误:"Null或空的全文谓词。"

如何绕过它?

下面是我的代码:

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

具有空文本框的搜索页面返回-空或空全文谓词

尝试添加以下内容作为BindRpt()

的第一行
if (string.IsNullOrEmpty(Search.Text)) return;

更新以下条件:

if (pgitems.Count > 1)

if (pgitems.Count > 0)