Untuk menghapus semua baris dalam tabel, saat ini saya melakukan hal berikut:
context.Entities.DeleteAllOnSubmit(context.Entities);
context.SubmitChanges();
Namun, ini sepertinya memakan waktu lama. Apakah ada cara yang lebih cepat?
c#
linq-to-sql
delete-row
Svish
sumber
sumber
Jawaban:
Anda dapat melakukan perintah pemotongan atau hapus SQL normal, menggunakan metode DataContext.ExecuteCommand :
context.ExecuteCommand("DELETE FROM Entity");
Atau
context.ExecuteCommand("TRUNCATE TABLE Entity");
Cara Anda menghapus memakan waktu lama karena Linq ke SQL menghasilkan pernyataan DELETE untuk setiap entitas , ada pendekatan tipe-aman lain untuk melakukan penghapusan / pembaruan batch, periksa artikel berikut ini:
sumber
TRUNCATE
sebelumnya tanpa masalah pada Linq-ke-SQLSayangnya LINQ-to-SQL tidak mengeksekusi kueri berbasis set dengan sangat baik.
Anda akan berasumsi seperti itu
akan diterjemahkan menjadi sesuatu seperti
tapi sayangnya itu lebih mirip
Anda akan menemukan hal yang sama ketika Anda mencoba melakukan pembaruan massal di LINQ-to-SQL. Lebih dari beberapa ratus baris sekaligus dan itu akan menjadi terlalu lambat.
Jika Anda perlu melakukan operasi batch & Anda menggunakan LINQ-to-SQL, Anda perlu menulis prosedur yang tersimpan.
sumber
Saya suka menggunakan Metode Ekstensi, seperti yang berikut ini:
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); } }
sumber
Anda juga bisa menggunakan ini:
Public void BorraFilasTabla() { using(basededatos db = new basededatos()) { var ListaParaBorrar = db.Tabla.Tolist(); db.Tabla.RemoveRange(ListaParaBorrar); } }
sumber
Kode c # di bawah ini digunakan untuk Sisipkan / Perbarui / Hapus / Hapus Semua pada tabel database menggunakan LINQ ke 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(); } } }
sumber