DELETE From Table
WHERE ID in (1,2,3, ... )
Is there any way to produce following query in LINQ
? I tried RemoveRange
, but from SQL Server Profiler
find that it actually deletes records separately
DELETE From Table
WHERE ID in (1,2,3, ... )
Is there any way to produce following query in LINQ
? I tried RemoveRange
, but from SQL Server Profiler
find that it actually deletes records separately
You could first define the item(s) to remove, then iterate over the list removing them one by one: (note that the whole operation has to be done inside database context scope otherwise it won't work)
var toRemove = list.Where(l => l.id == 1 || l.id == 2 || l.id == 3);
foreach (var item in toRemove)
{
databasecontext.table.Remove(item); //replace databasecontext.table with your own context and table name
}
You can write it in single line
table.RemoveAll(tbl => tbl.id == 1 || tbl.id == 2 || tbl.id == 3);
Hope this helps.
Try this piece of code to make this, It will work for you.
DataContextClass _DbContext = new DataContextClass();
var remove = _DbContext.tableName.where(x=>x.id >= 1 && x.id <= endValue);
if(remove != null)
{
db.logins.RemoveRange(remove);
db.SaveChanges();
}