我使用 nhibernate 作為我的網(wǎng)絡(luò)服務(wù)的 orm,我已經(jīng)實(shí)現(xiàn)了一個 CustomSqlDriver。我創(chuàng)建 CustomSqlDriver 的原因是因?yàn)槲倚枰@取并保存在應(yīng)用程序中執(zhí)行的每個查詢(及其參數(shù)值)到數(shù)據(jù)庫。每次發(fā)生查詢(選擇、更新等)時都會調(diào)用 AdjustCommand 方法并按相應(yīng)的順序調(diào)用。public class CustomSqlDriver : SqlClientDriver { private static readonly log4net.ILog log = log4net.LogManager.GetLogger("CustomSqlClientDriverLogger"); private static readonly Object _lock = new Object(); public override void AdjustCommand(IDbCommand command) { base.AdjustCommand(command); var parameters = (SqlParameterCollection)command.Parameters; QueryType queryType = GetQueryType(command); string tableName = GetTableName(command.CommandText); string fullCommandText = GetFullQuery(command, parameters); Task.Run(() => { lock (_lock) { log.Info($"Trying to save the query = {fullCommandText}"); SaveToDb((int)queryType, fullCommandText, tableName); } }); }}我需要按順序保存每個查詢,因?yàn)樯院笪覍⒃诓煌?FIFO 進(jìn)程中使用它們。不能在同一個線程中完成(因?yàn)樗赡芎苈?。如您所見,我嘗試在 Task.Run() 中的靜態(tài)對象上使用鎖,只要對任何 webmethod 的調(diào)用是同步的,就可以工作,但如果我并行調(diào)用它們,則某些行在保存時會丟失順序到數(shù)據(jù)庫。我不確定這是最好的方法 D:任何幫助將不勝感激。
鎖定在 Web 方法上的 Task.Run() 內(nèi)不起作用 c#?
慕工程0101907
2021-09-19 15:37:53