|
|
Diposting padaKemarin pukul 20:48
|
|
|

Persyaratan: Beberapa data memungkinkan pembacaan kotor, seperti konten artikel, tampilan halaman, komentar, dll., yang tidak seketat data keuangan. Untuk meningkatkan performa kueri, transaksi ReadUncommitted dapat digunakan, tetapi SqlTransaction dan TransactionScope memiliki bug tingkat isolasi kebocoran yang belum diperbaiki, jadi pertimbangkan untuk menggunakan solusi WITH (NOLOCK).
Resensi:
Tingkat isolasi kebocoran SqlTransaction dan TransactionScope (bug ini telah ada selama 8 tahun dan masih belum diperbaiki!) Saya memperkirakan banyak orang mungkin terpengaruh, tetapi mungkin tidak menyadarinya):Login hyperlink terlihat.
Artikel ini perlu mereferensikan SqlScriptDOM untuk mengurai pernyataan SQL dan menambahkan WITH(NOLOCK). Lihat proyek sumber terbuka:Login hyperlink terlihat.
Nuget mengutip sebagai berikut:
Buat fitur AllowDirtyReadAttribute.cs baru, kode sebagai berikut:
Buat WithNoLockInterceptor baru untuk mengganti metode tertentu di DbCommandInterceptor. Kodenya adalah sebagai berikut:
Injeksikan ke EF Core dengan konfigurasi berikut:
Gunakan untuk menambahkannya di atas metode pengontrol[Izinkan Membacanya]Bisa.
Pernyataan SQL mentah:
PILIH [o]. [Id], [o]. [Nama Pelanggan], [o0]. [Id], [o0]. [UrutanId], [o0]. [Produk] DARI [Perintah] AS [o] SAMBUNGAN LUAR KIRI [Garis Pesanan] SEBAGAI [o0] PADA [o]. [Id] = [o0]. [UrutanId] DI MANA [o]. [Id] = 1 PERINTAH OLEH [o]. [Id]; Pernyataan yang dihasilkan setelah menambahkan NOLOCK:
PILIH [o]. [Id], [o]. [Nama Pelanggan], [o0]. [Id], [o0]. [UrutanId], [o0]. [Produk] DARI [Perintah] SEBAGAI [o] DENGAN (NOLOCK) SAMBUNGAN LUAR KIRI [Garis Pesanan] SEPERTI [o0] DENGAN (NOLOCK) PADA [o]. [Id] = [o0]. [UrutanId] DI MANA [o]. [Id] = 1 PERINTAH OLEH [o]. [Id]; |
Mantan:(MSSQL) Pencarian Teks Lengkap SQL Server, Indeks Teks Lengkap
|