Parameterized dynamic sql query

前端 未结 2 776
日久生厌
日久生厌 2020-12-10 18:33

I have a list of keywords that i store in a list.

To fetch records from a table, am using the following query:

sqlBuilder.Append(\"SELECT name, membe         


        
2条回答
  •  暖寄归人
    2020-12-10 19:07

    Do not put the wildcard characters in your querystring, but add them to your parameter-value:

    sql = "SELECT name FROM members WHERE Name LIKE @p_name";
    ...
    cmd.Parameters.AddWithValue("@p_name", "%" + item + "%");
    

    When you add the wildcard characters inside your query-string, the parameter will be escaped, but the wildcard chars will not; that will result in a query that is sent to the DB that looks like this:

    SELECT name FROM members WHERE Name LIKE %'somename'%
    

    which is obviously not correct.

    Next to that, you're creating a SqlCommand in a loop which is not necessary. Also, you're creating parameters with a non-unique name, since you're adding them in a loop, and the parameter always has the same name. You also need to remove the last AND keyword, when you exit the loop.

提交回复
热议问题