Pour supprimer toutes les lignes d'un tableau, je fais actuellement ce qui suit:
context.Entities.DeleteAllOnSubmit(context.Entities);
context.SubmitChanges();
Cependant, cela semble prendre des siècles. Y at-il un moyen plus rapide?
c#
linq-to-sql
delete-row
Svish
la source
la source
Réponses:
Vous pouvez exécuter une commande SQL normale de troncature ou de suppression à l'aide de la méthode DataContext.ExecuteCommand :
context.ExecuteCommand("DELETE FROM Entity");
Ou
context.ExecuteCommand("TRUNCATE TABLE Entity");
La façon dont vous supprimez prend du temps car Linq to SQL génère une instruction DELETE pour chaque entité , il existe d'autres approches de type sécurisé pour effectuer des suppressions / mises à jour par lots, consultez les articles suivants:
la source
TRUNCATE
sans problème sur Linq-to-SQLMalheureusement, LINQ-to-SQL n'exécute pas très bien les requêtes basées sur des ensembles.
Vous supposeriez que
se traduira par quelque chose comme
mais malheureusement c'est plus comme
Vous trouverez la même chose lorsque vous essayez d'effectuer une mise à jour en bloc dans LINQ-to-SQL. Plus de quelques centaines de lignes à la fois et ça va tout simplement être trop lent.
Si vous devez effectuer des opérations par lots et que vous utilisez LINQ-to-SQL, vous devez écrire des procédures stockées.
la source
J'aime utiliser une méthode d'extension, comme suit:
public static class LinqExtension { public static void Truncate<TEntity>(this Table<TEntity> table) where TEntity : class { var rowType = table.GetType().GetGenericArguments()[0]; var tableName = table.Context.Mapping.GetTable(rowType).TableName; var sqlCommand = String.Format("TRUNCATE TABLE {0}", tableName); table.Context.ExecuteCommand(sqlCommand); } }
la source
vous pouvez également utiliser ceci:
Public void BorraFilasTabla() { using(basededatos db = new basededatos()) { var ListaParaBorrar = db.Tabla.Tolist(); db.Tabla.RemoveRange(ListaParaBorrar); } }
la source
Le code ci-dessous c # est utilisé pour insérer / mettre à jour / supprimer / supprimer tout sur une table de base de données en utilisant LINQ to SQL
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Text.RegularExpressions; namespace PracticeApp { class PracticeApp { public void InsertRecord(string Name, string Dept) { LinqToSQLDataContext LTDT = new LinqToSQLDataContext(); LINQTOSQL0 L0 = new LINQTOSQL0 { NAME = Name, DEPARTMENT = Dept }; LTDT.LINQTOSQL0s.InsertOnSubmit(L0); LTDT.SubmitChanges(); } public void UpdateRecord(int ID, string Name, string Dept) { LinqToSQLDataContext LTDT = new LinqToSQLDataContext(); LINQTOSQL0 L0 = (from item in LTDT.LINQTOSQL0s where item.ID == ID select item).FirstOrDefault(); L0.NAME = Name; L0.DEPARTMENT = Dept; LTDT.SubmitChanges(); } public void DeleteRecord(int ID) { LinqToSQLDataContext LTDT = new LinqToSQLDataContext(); LINQTOSQL0 L0; if (ID != 0) { L0 = (from item in LTDT.LINQTOSQL0s where item.ID == ID select item).FirstOrDefault(); LTDT.LINQTOSQL0s.DeleteOnSubmit(L0); } else { IEnumerable<LINQTOSQL0> Data = from item in LTDT.LINQTOSQL0s where item.ID !=0 select item; LTDT.LINQTOSQL0s.DeleteAllOnSubmit(Data); } LTDT.SubmitChanges(); } static void Main(string[] args) { Console.Write("* Enter Comma Separated Values to Insert Records\n* To Delete a Record Enter 'Delete' or To Update the Record Enter 'Update' Then Enter the Values\n* Dont Pass ID While Inserting Record.\n* To Delete All Records Pass 0 as Parameter for Delete.\n"); var message = "Successfully Completed"; try { PracticeApp pa = new PracticeApp(); var enteredValue = Console.ReadLine(); if (Regex.Split(enteredValue, ",")[0] == "Delete") { Console.Write("Delete Operation in Progress...\n"); pa.DeleteRecord(Int32.Parse(Regex.Split(enteredValue, ",")[1])); } else if (Regex.Split(enteredValue, ",")[0] == "Update") { Console.Write("Update Operation in Progress...\n"); pa.UpdateRecord(Int32.Parse(Regex.Split(enteredValue, ",")[1]), Regex.Split(enteredValue, ",")[2], Regex.Split(enteredValue, ",")[3]); } else { Console.Write("Insert Operation in Progress...\n"); pa.InsertRecord(Regex.Split(enteredValue, ",")[0], Regex.Split(enteredValue, ",")[1]); } } catch (Exception ex) { message = ex.ToString(); } Console.Write(message); Console.ReadLine(); } } }
la source