好问题
Good  Question
  • 首 页
  • 问题
    • PHP
    • JAVA
    • CPlusPlus
    • C#
    • SQL
  • 关 于
  • 联 系
参数化SQL IN子句 关闭 返回上一级  

参数化SQL IN子句
+ 查看更多

发布日期:2018-02-24 16:52
分类:SQL
浏览次数:52
如何参数化一个包含具有可变数量参数的IN子句的查询,像如下这样:
select * from Tags 
where Name in ('ruby','rails','scruffy','rubyonrails')
order by Count desc
在此查询中,参数的数量可以是1到5之间的任何值。
我不喜欢使用专用的存储过程(或XML),但如果有一些特定于SQL Server 2008的好的方法,我也是可以接受的。

回答:

这儿有一个应急的技巧,我使用:
select * from Tags
where '|ruby|rails|scruffy|rubyonrails|'
like '%|' + Name + '|%'
这是C#代码:

string[] tags = new string[] { "ruby", "rails", "scruffy", "rubyonrails" };
const string cmdText = "select * from tags where '|' + @tags + '|' like '%|' + Name + '|%'";

using (SqlCommand cmd = new SqlCommand(cmdText)) {
   cmd.Parameters.AddWithValue("@tags", string.Join("|", tags);
}

两个警告:
·这样性能不太好。像“%...%”的查询不被索引。
·请确保你没有任何|,空白或者空标记,否则将无法使用。
还有其他的方法做到这一点,有些人可能有更好的方法,所以请继续阅读。
上一篇在一个SQL表中查找重复值
UNION和UNION ALL之间有什么区别?下一篇
下一篇UNION和UNION ALL之间有什么区别?

最新文章

  • 函数`__construct`用来干嘛的
    发布日期:2018-03-26
  • 通过访客的IP得到他们的地区
    发布日期:2018-03-26
  • 合并两个PHP对象的最好的方法是什么?
    发布日期:2018-03-26
  • 该如何把一该如何把一个对象转化成数组?
    发布日期:2018-03-26
  • 什么是输出缓冲区?
    发布日期:2018-03-26
  • 在PHP中怎么把用逗号分隔的字符串分隔在一个数组里?
    发布日期:2018-03-26
  • 在PHP中使用foreach循环时查找数组的最后一个元素
    发布日期:2018-03-26
关于好问
收集整理一些有用的问题和回答,造福中国的程序旺和IT喵们!
友情链接
起飞页 
相关信息
版权声明
Copyright © 2016 - 2022  苏州卡达网络科技有限公司 备案号:苏ICP备09008221号