| 
									
										
										
										
											2022-07-29 22:44:21 +08:00
										 |  |  |  | using SqlSugar; | 
					
						
							|  |  |  |  | using System; | 
					
						
							|  |  |  |  | using System.Collections.Generic; | 
					
						
							|  |  |  |  | using System.Linq; | 
					
						
							|  |  |  |  | using System.Text; | 
					
						
							| 
									
										
										
										
											2023-10-10 13:28:34 +08:00
										 |  |  |  | using static OrmTest.DemoE_CodeFirst; | 
					
						
							| 
									
										
										
										
											2022-07-29 22:44:21 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | namespace OrmTest | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |     public class DemoE_CodeFirst | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |         public static void Init() | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             Console.WriteLine(""); | 
					
						
							|  |  |  |  |             Console.WriteLine("#### CodeFirst Start ####"); | 
					
						
							|  |  |  |  |             SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 DbType = DbType.QuestDB, | 
					
						
							|  |  |  |  |                 ConnectionString = Config.ConnectionString3, | 
					
						
							|  |  |  |  |                 InitKeyType = InitKeyType.Attribute, | 
					
						
							|  |  |  |  |                 IsAutoCloseConnection = true | 
					
						
							|  |  |  |  |             }); | 
					
						
							| 
									
										
										
										
											2022-08-14 08:21:23 +08:00
										 |  |  |  |             db.Aop.OnLogExecuting = (s, p) => | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 Console.WriteLine(s); | 
					
						
							|  |  |  |  |             }; | 
					
						
							| 
									
										
										
										
											2023-10-10 13:28:34 +08:00
										 |  |  |  |             db.CodeFirst.InitTables<QuestdbTestData3>(); | 
					
						
							| 
									
										
										
										
											2022-07-31 21:07:17 +08:00
										 |  |  |  |             db.DbMaintenance.CreateDatabase(); | 
					
						
							| 
									
										
										
										
											2022-07-29 22:44:21 +08:00
										 |  |  |  |             db.CodeFirst.InitTables(typeof(CodeFirstTable1));//Create CodeFirstTable1  | 
					
						
							| 
									
										
										
										
											2022-07-31 21:07:17 +08:00
										 |  |  |  |             db.Insertable(new CodeFirstTable1() { Name = "a", Text = "a" }).ExecuteCommand(); | 
					
						
							| 
									
										
										
										
											2022-07-29 22:44:21 +08:00
										 |  |  |  |             var list = db.Queryable<CodeFirstTable1>().ToList(); | 
					
						
							| 
									
										
										
										
											2022-07-31 17:48:25 +08:00
										 |  |  |  |             db.CodeFirst.InitTables<IndexClass>(); | 
					
						
							| 
									
										
										
										
											2022-07-31 21:07:17 +08:00
										 |  |  |  |             db.CodeFirst.InitTables<SplitTableEntity>(); | 
					
						
							| 
									
										
										
										
											2022-08-14 07:02:24 +08:00
										 |  |  |  |             TestBool(db); | 
					
						
							|  |  |  |  |             TestGuid(db); | 
					
						
							| 
									
										
										
										
											2022-07-29 22:44:21 +08:00
										 |  |  |  |             Console.WriteLine("#### CodeFirst end ####"); | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-10-10 13:28:34 +08:00
										 |  |  |  |         [SugarTable("QuestdbTestData3")] | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         public class QuestdbTestData3 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             //不支持自增和主键 (标识主键是用来更新用的) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             [SugarColumn(IsPrimaryKey = true)] | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             public string Id { get; set; } | 
					
						
							|  |  |  |  |             [SugarColumn(IsJson = true)] | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             public List<QuestdbTestData> Data { get; set; } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             [TimeDbSplitField(DateType.Year)] | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             public DateTime Time1 { get; set; } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         public class QuestdbTestData | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             public int xx { get; set; } | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-08-14 07:02:24 +08:00
										 |  |  |  |         private static void TestGuid(SqlSugarClient db) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             db.CodeFirst.InitTables<GuidTest>(); | 
					
						
							| 
									
										
										
										
											2022-08-14 08:28:53 +08:00
										 |  |  |  |             //db.DbMaintenance.TruncateTable("BoolTest"); | 
					
						
							|  |  |  |  |             var Id =SnowFlakeSingle.Instance.NextId(); | 
					
						
							| 
									
										
										
										
											2022-08-14 07:02:24 +08:00
										 |  |  |  |             db.Insertable<GuidTest>(new GuidTest() { A = Guid.Empty, Id = Id }).ExecuteCommand(); | 
					
						
							|  |  |  |  |             Console.Write(db.Queryable<GuidTest>().First().A); | 
					
						
							|  |  |  |  |             db.Updateable<GuidTest>(new GuidTest() { A = Guid.NewGuid(), Id = Id }).ExecuteCommand(); | 
					
						
							|  |  |  |  |             Console.Write(db.Queryable<GuidTest>().First().A); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         private static void TestBool(SqlSugarClient db) | 
					
						
							|  |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2022-08-14 08:21:23 +08:00
										 |  |  |  |             db.CodeFirst.InitTables<BoolTest5>(); | 
					
						
							| 
									
										
										
										
											2022-08-14 08:28:53 +08:00
										 |  |  |  |             //db.DbMaintenance.TruncateTable("BoolTest3"); | 
					
						
							|  |  |  |  |             var Id = SnowFlakeSingle.Instance.NextId(); | 
					
						
							| 
									
										
										
										
											2022-08-14 08:21:23 +08:00
										 |  |  |  |             db.Insertable<BoolTest5>(new List<BoolTest5>(){ new BoolTest5() {  dateTime=DateTime.Now,A = true, Id = Id } }).ExecuteCommand(); | 
					
						
							| 
									
										
										
										
											2022-08-14 08:28:53 +08:00
										 |  |  |  |             Console.Write(db.Queryable<BoolTest5>().First(it=>it.Id==Id).A); | 
					
						
							| 
									
										
										
										
											2022-08-14 08:21:23 +08:00
										 |  |  |  |             //db.Updateable<BoolTest4>(new BoolTest4() { dateTime = DateTime.Now,A = false, Id = Id }).ExecuteCommand(); | 
					
						
							| 
									
										
										
										
											2022-08-14 08:24:44 +08:00
										 |  |  |  |             db.Updateable<BoolTest5>(  new BoolTest5() { dateTime = DateTime.Now, A = false, Id = Id  }).ExecuteCommand(); | 
					
						
							| 
									
										
										
										
											2023-06-22 00:16:49 +08:00
										 |  |  |  |             db.CodeFirst.InitTables<UnitSiafayyy>(); | 
					
						
							|  |  |  |  |             var list=db.Queryable<UnitSiafayyy>().SampleBy(1, SampleByUnit.Minute) | 
					
						
							|  |  |  |  |                 .Select(it=>new {  | 
					
						
							|  |  |  |  |                   Id=SqlFunc.AggregateMin(it.Id), | 
					
						
							|  |  |  |  |                   Count=SqlFunc.AggregateCount(it.Id) | 
					
						
							|  |  |  |  |                 }) | 
					
						
							|  |  |  |  |                 .ToList(); | 
					
						
							| 
									
										
										
										
											2022-08-14 08:28:53 +08:00
										 |  |  |  |             Console.Write(db.Queryable<BoolTest5>().First(it => it.Id == Id).A); | 
					
						
							| 
									
										
										
										
											2022-08-14 07:02:24 +08:00
										 |  |  |  |         } | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-06-22 00:16:49 +08:00
										 |  |  |  |     public class UnitSiafayyy | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |         [SugarColumn(IsPrimaryKey = true)] | 
					
						
							|  |  |  |  |         public long Id { get; set; } | 
					
						
							|  |  |  |  |         [TimeDbSplitField(DateType.Day)] | 
					
						
							|  |  |  |  |         public DateTime DateTime { get; set; } | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-08-14 07:02:24 +08:00
										 |  |  |  |     public class GuidTest | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |         [SugarColumn(IsPrimaryKey = true)] | 
					
						
							|  |  |  |  |         public long Id { get; set; } | 
					
						
							|  |  |  |  |         public Guid A { get; set; } | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-08-14 08:21:23 +08:00
										 |  |  |  |     public class BoolTest5 | 
					
						
							| 
									
										
										
										
											2022-08-14 07:02:24 +08:00
										 |  |  |  |     { | 
					
						
							|  |  |  |  |         [SugarColumn(IsPrimaryKey = true)] | 
					
						
							|  |  |  |  |         public long Id { get; set; } | 
					
						
							|  |  |  |  |         public bool A { get; set; } | 
					
						
							| 
									
										
										
										
											2022-08-14 08:21:23 +08:00
										 |  |  |  |         public DateTime dateTime { get; set; } | 
					
						
							| 
									
										
										
										
											2022-07-29 22:44:21 +08:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-31 21:07:17 +08:00
										 |  |  |  |     [SugarIndex(null, nameof(IndexClass.Name), OrderByType.Asc)] | 
					
						
							|  |  |  |  |     public class IndexClass | 
					
						
							| 
									
										
										
										
											2022-07-31 17:48:25 +08:00
										 |  |  |  |     { | 
					
						
							|  |  |  |  |         public int Id { get; set; } | 
					
						
							| 
									
										
										
										
											2022-07-31 21:07:17 +08:00
										 |  |  |  |         [SugarColumn(ColumnDataType = "symbol")] | 
					
						
							| 
									
										
										
										
											2022-07-31 17:48:25 +08:00
										 |  |  |  |         public string Name { get; set; } | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-07-31 21:07:17 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     public class SplitTableEntity | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |         public string Id { get; set; } | 
					
						
							|  |  |  |  |         [TimeDbSplitField(DateType.Day)] | 
					
						
							|  |  |  |  |         public DateTime Ts { get; set; } | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-29 22:44:21 +08:00
										 |  |  |  |     public class CodeFirstTable1 | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |         [SugarColumn(IsIdentity = true, IsPrimaryKey = true)] | 
					
						
							|  |  |  |  |         public int Id { get; set; } | 
					
						
							|  |  |  |  |         public string Name { get; set; } | 
					
						
							| 
									
										
										
										
											2022-07-30 14:58:21 +08:00
										 |  |  |  |         [SugarColumn(ColumnDataType = "string")]//custom | 
					
						
							| 
									
										
										
										
											2022-07-29 22:44:21 +08:00
										 |  |  |  |         public string Text { get; set; } | 
					
						
							|  |  |  |  |         [SugarColumn(IsNullable = true)] | 
					
						
							|  |  |  |  |         public DateTime CreateTime { get; set; } | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | } |