SQL选择List <string>中的值的位置

Joe*_*ess 10 .net sql ado.net

有没有办法可以针对具有指向ArrayList或List的where子句的数据源(可能是sql,oracle或access)创建查询?

例:

Select * from Table where RecordID in (RecordIDList)
Run Code Online (Sandbox Code Playgroud)

我已经看到了一些方法可以用Linq做到这一点,但如果它可以避免,我宁愿不诉诸它.

And*_*are 12

你可以用String.Join.尝试这样的事情:

String query = "select * from table where RecordId in ({0});";
String formatted = String.Format(query, String.Join(",", list.ToArray()));
Run Code Online (Sandbox Code Playgroud)

作为旁注,这不会保护您免受SQL注入 - 希望此示例将指向正确的方向.

  • 当然,在一般情况下,通过字符串连接构建SQL查询是一个坏主意,但如果RecordIds列表是强类型的整数列表,则此方法没有SQL注入的风险. (6认同)

Amy*_*y B 7

Linq到Sql.RecordList应该是a List<T>,而不是an ArrayList或anIList<T>

IEnumerable<TableRow> query =
  from t in db.Table
  where RecordList.Any(r => t.RecordId == r)
  select t;
Run Code Online (Sandbox Code Playgroud)

这将生成带参数的sql:

SELECT *
FROM Table
WHERE RecordId in (@p0, @p1, @p2, @p3, @p4)
Run Code Online (Sandbox Code Playgroud)

Linq将生成所需数量的参数.某些数据库实现受限于可以接受的参数数量.SqlServer2005的限制是超过2000个参数...所以不要使用超过2000个元素的列表.


Gor*_*onB 6

我只是用逗号分隔的列表做了你想做的事情

Select * from Table where RecordID in (1,2,34,45,76,34,457,34)
Run Code Online (Sandbox Code Playgroud)

或者结果来自单独的选择

Select * from Table where RecordID in (select recordId from otherTable where afieldtype=1)
Run Code Online (Sandbox Code Playgroud)

我很确定你无法实现你所追求的目标....