解決ASP.NET的SqlCommand,利用SqlParameter來下SQL指令"Where In"的問題
前陣子在討論區看到這方面的問題...小弟去測了一下..有以下心得...
資料表內容如下:
data:image/s3,"s3://crabby-images/eaafa/eaafaf7c9666759e7b4077c1d75e5d4f8e3a66e7" alt=""
一般作法,sql where in字串,全由使用者定義
string queryString =
"SELECT id,gender,name FROM [user] Where id in(19,21,24)";
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
SqlCommand cmd =
new SqlCommand(queryString, conn);
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
SqlDataAdapter adapter =
new SqlDataAdapter(cmd);
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
DataTable dt =
new DataTable();
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
adapter.Fill(dt);
this.GridView1.DataSource = dt;
this.GridView1.DataBind();
參數作法,sql where in字串,使用@IdGroup方式,@IdGroup = 19,這樣是正常可以run的
string queryString =
"SELECT id,gender,name FROM [user] Where id in(@IdGroup)";
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
SqlCommand cmd =
new SqlCommand(queryString, conn);
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
cmd.Parameters.Add(
"@IdGroup",
"19");
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
SqlDataAdapter adapter =
new SqlDataAdapter(cmd);
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
DataTable dt =
new DataTable();
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
adapter.Fill(dt);
this.GridView1.DataSource = dt;
this.GridView1.DataBind();
參數作法,sql where in字串,使用@IdGroup方式,@IdGroup = 19,21,24,這樣會產生錯誤
string queryString =
"SELECT id,gender,name FROM [user] Where id in(@IdGroup)";
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
SqlCommand cmd =
new SqlCommand(queryString, conn);
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
cmd.Parameters.Add(
"@IdGroup",
"19,21,24");
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
SqlDataAdapter adapter =
new SqlDataAdapter(cmd);
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
DataTable dt =
new DataTable();
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
adapter.Fill(dt);
this.GridView1.DataSource = dt;
this.GridView1.DataBind();
解決方法,將參數分成多個,例如 where id in(@param1,@param2,@param3),然後設定每一個參數的值
string query =
"19,21,24";
string[] param = query.Split(',');
string temp = "";
for (
int i = 0; i < param.Length; i++)
data:image/s3,"s3://crabby-images/951a9/951a9c99c3e9d473288a3a429857325952eefdb7" alt=""
...{
temp += "@param" + i.ToString() + ",";
}
string queryString =
"SELECT id,gender,name FROM [user] Where id in(" + temp.Substring(0, temp.Length - 1) +
")";
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
SqlCommand cmd =
new SqlCommand(queryString, conn);
for (
int i = 0; i < param.Length; i++)
data:image/s3,"s3://crabby-images/9e143/9e14368ed21ee82f813c16cc9a1abc7999314972" alt=""
...{
cmd.Parameters.Add("@param" + i.ToString(), SqlDbType.Int).Value = param[i];
}
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
SqlDataAdapter adapter =
new SqlDataAdapter(cmd);
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
DataTable dt =
new DataTable();
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
adapter.Fill(dt);
this.GridView1.DataSource = dt;
this.GridView1.DataBind();
執行結果:
data:image/s3,"s3://crabby-images/a9af2/a9af299fa97cedfa2a7d358d2ec8a0ee45dc9d69" alt=""