| 
									
										
										
										
											2023-11-06 21:44:56 +08:00
										 |  |  |  | using SqlSeverTest.UserTestCases; | 
					
						
							|  |  |  |  | using SqlSugar; | 
					
						
							| 
									
										
										
										
											2019-05-21 12:57:51 +08:00
										 |  |  |  | using System; | 
					
						
							|  |  |  |  | using System.Collections.Generic; | 
					
						
							|  |  |  |  | using System.Linq; | 
					
						
							|  |  |  |  | using System.Text; | 
					
						
							|  |  |  |  | using System.Threading.Tasks; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | namespace OrmTest | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |     public partial class NewUnitTest | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         public static SqlSugarClient simpleDb => new SqlSugarClient(new ConnectionConfig() | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             DbType = DbType.SqlServer, | 
					
						
							|  |  |  |  |             ConnectionString = Config.ConnectionString, | 
					
						
							|  |  |  |  |             InitKeyType = InitKeyType.Attribute, | 
					
						
							|  |  |  |  |             IsAutoCloseConnection = true, | 
					
						
							|  |  |  |  |             AopEvents = new AopEvents | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 OnLogExecuting = (sql, p) => | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     Console.WriteLine(sql); | 
					
						
							|  |  |  |  |                     Console.WriteLine(string.Join(",", p?.Select(it => it.ParameterName + ":" + it.Value))); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         }); | 
					
						
							| 
									
										
										
										
											2021-10-31 17:44:48 +08:00
										 |  |  |  |         public static SqlSugarScope ssDb => new SqlSugarScope(new ConnectionConfig() | 
					
						
							| 
									
										
										
										
											2019-05-21 12:57:51 +08:00
										 |  |  |  |         { | 
					
						
							|  |  |  |  |             DbType = DbType.SqlServer, | 
					
						
							|  |  |  |  |             ConnectionString = Config.ConnectionString, | 
					
						
							|  |  |  |  |             InitKeyType = InitKeyType.Attribute, | 
					
						
							|  |  |  |  |             IsAutoCloseConnection = true, | 
					
						
							| 
									
										
										
										
											2021-10-31 17:44:48 +08:00
										 |  |  |  |             //IsShardSameThread = true, | 
					
						
							| 
									
										
										
										
											2019-05-21 12:57:51 +08:00
										 |  |  |  |             AopEvents = new AopEvents | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 OnLogExecuting = (sql, p) => | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     Console.WriteLine(sql); | 
					
						
							|  |  |  |  |                     Console.WriteLine(string.Join(",", p?.Select(it => it.ParameterName + ":" + it.Value))); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |         public static SqlSugarClient singleDb =  new SqlSugarClient(new ConnectionConfig() | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             DbType = DbType.SqlServer, | 
					
						
							|  |  |  |  |             ConnectionString = Config.ConnectionString, | 
					
						
							|  |  |  |  |             InitKeyType = InitKeyType.Attribute, | 
					
						
							|  |  |  |  |             IsAutoCloseConnection = true, | 
					
						
							|  |  |  |  |             AopEvents = new AopEvents | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 OnLogExecuting = (sql, p) => | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     Console.WriteLine(sql); | 
					
						
							|  |  |  |  |                     Console.WriteLine(string.Join(",", p?.Select(it => it.ParameterName + ":" + it.Value))); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         }); | 
					
						
							| 
									
										
										
										
											2021-10-31 17:50:21 +08:00
										 |  |  |  |         public static SqlSugarScope singleAndSsDb = new SqlSugarScope(new ConnectionConfig() | 
					
						
							| 
									
										
										
										
											2019-05-21 12:57:51 +08:00
										 |  |  |  |         { | 
					
						
							|  |  |  |  |             DbType = DbType.SqlServer, | 
					
						
							|  |  |  |  |             ConnectionString = Config.ConnectionString, | 
					
						
							|  |  |  |  |             InitKeyType = InitKeyType.Attribute, | 
					
						
							|  |  |  |  |             IsAutoCloseConnection = true, | 
					
						
							| 
									
										
										
										
											2021-10-31 17:50:21 +08:00
										 |  |  |  |             //IsShardSameThread = true, | 
					
						
							| 
									
										
										
										
											2019-05-21 12:57:51 +08:00
										 |  |  |  |             AopEvents = new AopEvents | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 OnLogExecuting = (sql, p) => | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     Console.WriteLine(sql); | 
					
						
							|  |  |  |  |                     Console.WriteLine(string.Join(",", p?.Select(it => it.ParameterName + ":" + it.Value))); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |         public static void Thread() | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             Simple(); | 
					
						
							|  |  |  |  |             IsShardSameThread(); | 
					
						
							|  |  |  |  |             Single(); | 
					
						
							|  |  |  |  |             SingleAndIsShardSameThread(); | 
					
						
							|  |  |  |  |             SimpleAsync(); | 
					
						
							|  |  |  |  |             IsShardSameThreadAsync(); | 
					
						
							|  |  |  |  |             SingleAsync(); | 
					
						
							|  |  |  |  |             SingleAndIsShardSameThreadAsync(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         private static void Simple() | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             var t1 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     simpleDb.Insertable(new Order() { Name = "test", CreateTime = DateTime.Now }).ExecuteCommand(); | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(1); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             var t2 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     simpleDb.Insertable(new Order() { Name = "test2", CreateTime = DateTime.Now }).ExecuteCommand(); | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(10); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             var t3 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     simpleDb.Insertable(new Order() { Name = "test3", CreateTime = DateTime.Now }).ExecuteCommand(); | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(6); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             t1.Start(); | 
					
						
							|  |  |  |  |             t2.Start(); | 
					
						
							|  |  |  |  |             t3.Start(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             Task.WaitAll(t1, t2, t3); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         private static void SingleAndIsShardSameThread() | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             var t1 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     singleAndSsDb.Insertable(new Order() { Name = "test", CreateTime = DateTime.Now }).ExecuteCommand(); | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(1); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             var t2 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     singleAndSsDb.Insertable(new Order() { Name = "test2", CreateTime = DateTime.Now }).ExecuteCommand(); | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(10); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             var t3 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     singleAndSsDb.Insertable(new Order() { Name = "test3", CreateTime = DateTime.Now }).ExecuteCommand(); | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(6); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             t1.Start(); | 
					
						
							|  |  |  |  |             t2.Start(); | 
					
						
							|  |  |  |  |             t3.Start(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             Task.WaitAll(t1, t2, t3); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         private static void Single() | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             var t1 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     singleDb.Insertable(new Order() { Name = "test", CreateTime = DateTime.Now }).ExecuteCommand(); | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(1); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             var t2 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     singleDb.Insertable(new Order() { Name = "test2", CreateTime = DateTime.Now }).ExecuteCommand(); | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(10); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             var t3 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     singleDb.Insertable(new Order() { Name = "test3", CreateTime = DateTime.Now }).ExecuteCommand(); | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(6); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             t1.Start(); | 
					
						
							|  |  |  |  |             t2.Start(); | 
					
						
							|  |  |  |  |             t3.Start(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             Task.WaitAll(t1, t2, t3); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         private static void IsShardSameThread() | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             var t1 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     Db.Insertable(new Order() { Name = "test", CreateTime = DateTime.Now }).ExecuteCommand(); | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(1); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             var t2 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     Db.Insertable(new Order() { Name = "test2", CreateTime = DateTime.Now }).ExecuteCommand(); | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(10); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             var t3 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     Db.Insertable(new Order() { Name = "test3", CreateTime = DateTime.Now }).ExecuteCommand(); | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(6); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             t1.Start(); | 
					
						
							|  |  |  |  |             t2.Start(); | 
					
						
							|  |  |  |  |             t3.Start(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             Task.WaitAll(t1, t2, t3); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         private static void SimpleAsync() | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             var t1 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     simpleDb.Insertable(new Order() { Name = "test", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(1); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             var t2 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     simpleDb.Insertable(new Order() { Name = "test2", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); ; | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(10); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             var t3 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     simpleDb.Insertable(new Order() { Name = "test3", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(6); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             t1.Start(); | 
					
						
							|  |  |  |  |             t2.Start(); | 
					
						
							|  |  |  |  |             t3.Start(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             Task.WaitAll(t1, t2, t3); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         private static void SingleAndIsShardSameThreadAsync() | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             var t1 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     singleAndSsDb.Insertable(new Order() { Name = "test", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(1); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             var t2 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     singleAndSsDb.Insertable(new Order() { Name = "test2", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(10); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             var t3 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     singleAndSsDb.Insertable(new Order() { Name = "test3", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(6); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             t1.Start(); | 
					
						
							|  |  |  |  |             t2.Start(); | 
					
						
							|  |  |  |  |             t3.Start(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             Task.WaitAll(t1, t2, t3); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         private static void SingleAsync() | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             var t1 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							| 
									
										
										
										
											2020-11-15 00:39:23 +08:00
										 |  |  |  |                     //singleDb.Insertable(new Order() { Name = "test", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); | 
					
						
							|  |  |  |  |                     //System.Threading.Thread.Sleep(1); No Support | 
					
						
							| 
									
										
										
										
											2019-05-21 12:57:51 +08:00
										 |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             var t2 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							| 
									
										
										
										
											2020-11-15 00:39:23 +08:00
										 |  |  |  |                     //singleDb.Insertable(new Order() { Name = "test2", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); | 
					
						
							|  |  |  |  |                     //System.Threading.Thread.Sleep(10); No Support | 
					
						
							| 
									
										
										
										
											2019-05-21 12:57:51 +08:00
										 |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             var t3 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							| 
									
										
										
										
											2020-11-15 00:39:23 +08:00
										 |  |  |  |                     //singleDb.Insertable(new Order() { Name = "test3", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); | 
					
						
							|  |  |  |  |                     //System.Threading.Thread.Sleep(6); No Support | 
					
						
							| 
									
										
										
										
											2019-05-21 12:57:51 +08:00
										 |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             t1.Start(); | 
					
						
							|  |  |  |  |             t2.Start(); | 
					
						
							|  |  |  |  |             t3.Start(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             Task.WaitAll(t1, t2, t3); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         private static void IsShardSameThreadAsync() | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             var t1 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     Db.Insertable(new Order() { Name = "test", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(1); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             var t2 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     Db.Insertable(new Order() { Name = "test2", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(10); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             var t3 = new Task(() => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 for (int i = 0; i < 100; i++) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     Db.Insertable(new Order() { Name = "test3", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); | 
					
						
							|  |  |  |  |                     System.Threading.Thread.Sleep(6); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |             t1.Start(); | 
					
						
							|  |  |  |  |             t2.Start(); | 
					
						
							|  |  |  |  |             t3.Start(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             Task.WaitAll(t1, t2, t3); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | } |