具有空文本框的搜索页面返回-空或空全文谓词
本文关键字:文谓词 谓词 文本 搜索 返回 | 更新日期: 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)