发布日期:2018-03-26
参数化SQL IN子句+ 查看更多
参数化SQL IN子句
+ 查看更多
发布日期:2018-02-24 16:52
分类:SQL
浏览次数:69
如何参数化一个包含具有可变数量参数的IN子句的查询,像如下这样:
select * from Tags where Name in ('ruby','rails','scruffy','rubyonrails') order by Count desc
在此查询中,参数的数量可以是1到5之间的任何值。
我不喜欢使用专用的存储过程(或XML),但如果有一些特定于SQL Server 2008的好的方法,我也是可以接受的。
两个警告:
·这样性能不太好。像“%...%”的查询不被索引。
·请确保你没有任何|,空白或者空标记,否则将无法使用。
还有其他的方法做到这一点,有些人可能有更好的方法,所以请继续阅读。
我不喜欢使用专用的存储过程(或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); }
两个警告:
·这样性能不太好。像“%...%”的查询不被索引。
·请确保你没有任何|,空白或者空标记,否则将无法使用。
还有其他的方法做到这一点,有些人可能有更好的方法,所以请继续阅读。