首頁 > 資料庫 > mysql教程 > 如何使用 LIKE 和 IN 子句正確參數化 SQL 查詢?

如何使用 LIKE 和 IN 子句正確參數化 SQL 查詢?

Mary-Kate Olsen
發布: 2024-12-30 07:00:11
原創
349 人瀏覽過

How to Properly Parameterize SQL Queries with LIKE and IN Clauses?

具有LIKE 和IN 條件的參數化查詢

參數化查詢中的一個常見障礙是處理涉及IN 和LIKE 子句的複雜條件。在這種情況下,確保使用正確的語法來實現參數化和有效性至關重要。

考慮以下場景:

SqlCommand comm = new SqlCommand(@"
   SELECT * 
   FROM   Products 
   WHERE  Category_ID IN (@categoryids) 
      OR  name LIKE '%@name%'
", 
   conn);
comm.Parameters.Add("@categoryids", SqlDbType.Int);
comm.Parameters["@categoryids"].Value = CategoryIDs;
comm.Parameters.Add("@name", SqlDbType.Int);
comm.Parameters["@name"].Value = Name;
登入後複製

這裡的目標是建構一個查詢根據以逗號分隔的類別ID (CategoryID) 列表和可能包含特殊字元的字串(Name) 檢索產品。但是,上面的程式碼將無法正常運行,因為:

  • CategoryIDs 被錯誤地分配給 SqlDbType.Int 和 SqlDbType.String。
  • Name 被指派給 SqlDbType.Int,即字串不正確。
  • 名稱中的特殊字元將不會被處理

正確的語法需要多步驟方法:

  1. 建立單獨的參數名稱:為每個類別建立參數名稱清單ID,如@p0、@p1、@pN-1。
  2. 新增參數指令: 遍歷類別 ID,使用對應的參數名稱為每個類別 ID 建立並新增一個參數。
  3. 建構名稱的模糊匹配: 將 % 連接到名稱參數周圍查詢字串以啟用模糊搜尋。

以下程式碼示範了修改後的方法:

string Name = "someone";
int[] categoryIDs = new int[] { 238, 1138, 1615, 1616, 1617,
                                1618, 1619, 1620, 1951, 1952,
                                1953, 1954, 1955, 1972, 2022 };

SqlCommand comm = conn.CreateCommand();

string[] parameters = new string[categoryIDs.Length];
for(int i=0;i<categoryIDs.Length;i++)
{
   parameters[i] = "@p"+i;
   comm.Parameters.AddWithValue(parameters[i], categoryIDs[i]);
}
comm.Parameters.AddWithValue("@name",$"%{Name}%");
comm.CommandText = "SELECT * FROM Products WHERE Category_ID IN (";
comm.CommandText += string.Join(",", parameters) + ")";
comm.CommandText += " OR name LIKE @name";
登入後複製

此程式碼產生一個完全參數化的查詢,滿足 IN 和 LIKE 條件的要求。

以上是如何使用 LIKE 和 IN 子句正確參數化 SQL 查詢?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板