4

SQL の LIKE 関数を使用して簡単な検索を実行したいと考えています。残念ながら、何らかの理由で、機能していないようです。以下は私のコードです。

private void gvbind()
{
    connection.Open();
    string sql = "";

    if (txtSearch.Text.Trim() == "")
    {
        sql = "SELECT a.cname,[bid],b.[bname],b.[baddress],b.[bcity],b.[bstate],b.[bpostcode],b.[bphone],b.[bfax],b.[bemail] FROM [CLIENT] a INNER JOIN [BRANCH] b ON a.clientID=b.clientID ORDER BY a.[clientID]";
    }
    else
    {
        sql = "SELECT a.cname,[bid],b.[bname],b.[baddress],b.[bcity],b.[bstate],b.[bpostcode],b.[bphone],b.[bfax],b.[bemail] FROM [CLIENT] a INNER JOIN [BRANCH] b ON a.clientID=b.clientID WHERE b.[bname] LIKE '%@search%' ORDER BY a.[clientID]";
    }

    SqlCommand cmd = new SqlCommand(sql,connection);
    cmd.Parameters.AddWithValue("@search", txtSearch.Text.Trim());
    cmd.CommandType = CommandType.Text;
    SqlDataAdapter adp = new SqlDataAdapter();
    adp.SelectCommand = cmd;
    DataSet ds = new DataSet();
    adp.Fill(ds);

    connection.Close();

    if (ds.Tables[0].Rows.Count > 0)
    {
        gvBranch.Enabled = true;
        gvBranch.DataSource = ds;
        gvBranch.DataBind();
    }
    else
    {
        ds.Tables[0].Rows.Add(ds.Tables[0].NewRow());
        ds.Tables[0].Rows.Add(ds.Tables[0].NewRow());

        gvBranch.DataSource = ds;
        gvBranch.DataBind();

        int columncount = gvBranch.Rows[0].Cells.Count;
        gvBranch.Rows[0].Cells.Clear();
        gvBranch.Rows[0].Cells.Add(new TableCell());
        gvBranch.Rows[0].Cells[0].ColumnSpan = columncount;
        gvBranch.Rows[0].Cells[0].Text = "No Records Found";
    }
    ds.Dispose();
}

上記のメソッドは、Page_Load() メソッドで呼び出されます。

if((!Page.IsPostBack))
{
    gvBind();
}

ボタン検索クリックでも呼び出されます。ただし、検索を実行するたびに No record found が返されます。

4

1 に答える 1

9

使用する

LIKE '%' + @search + '%'

それ以外の

LIKE '%@search%'

完全なクエリ;

...
else
{
    sql = "SELECT a.cname,[bid],b.[bname],b.[baddress],b.[bcity],b.[bstate],b.[bpostcode],b.[bphone],b.[bfax],b.[bemail] FROM [CLIENT] a INNER JOIN [BRANCH] b ON a.clientID=b.clientID WHERE b.[bname] LIKE '%' + @search + '%' ORDER BY a.[clientID]";
}

[]実際には、クエリのすべての列で角かっこ ( ) を使用する必要はありません。識別子またはオブジェクト名が予約済みのキーワードである場合に使用してください。

ありがとう。動作しますが、その説明はありますか?

主な問題はここにあります.クエリパラメータは引用符で囲まれています. 引用符で囲まれていると、SQL Server はそれを文字列リテラルとして認識し、パラメーターとして認識しません。

于 2013-09-05T07:48:08.580 に答える