mirror of
				https://gitee.com/dotnetchina/SqlSugar.git
				synced 2025-10-25 18:29:13 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			120 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			120 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using SqlSugar.DbConvert;
 | |
| using SqlSugar;
 | |
| using System;
 | |
| using System.Collections.Generic;
 | |
| using System.Linq;
 | |
| using System.Net;
 | |
| using System.Text;
 | |
| using System.Threading.Tasks;
 | |
| using System.Xml;
 | |
| 
 | |
| namespace OrmTest
 | |
| {
 | |
|     internal class UnitValueObject
 | |
|     {
 | |
|         public static void Init()
 | |
|         {
 | |
|             var db = NewUnitTest.Db;
 | |
|            
 | |
|             db.CodeFirst.InitTables<UnitafasMyEntity>();
 | |
|             db.Insertable(new UnitafasMyEntity()
 | |
|             {
 | |
|                  Id=Guid.NewGuid(),
 | |
|                   P0="a",
 | |
|                    P1=1,
 | |
|                     MyVO=new MyVO() { 
 | |
|                      GuidP1=Guid.NewGuid(),
 | |
|                       GuidP2=Guid.NewGuid(),
 | |
|                        VoId=Guid.NewGuid()
 | |
|                     }
 | |
|             }).ExecuteCommand();
 | |
|             var list5 = db.Queryable<UnitafasMyEntity>()
 | |
|                 .Select(e => new
 | |
|                 {
 | |
|                     e.Id,
 | |
|                     e.MyVO.GuidP1,
 | |
|                     e.MyVO.GuidP2
 | |
|                 })
 | |
|                 .ToListAsync().GetAwaiter().GetResult();
 | |
| 
 | |
|             var list6 = db.Queryable<UnitafasMyEntity>() 
 | |
|               .ToListAsync().GetAwaiter().GetResult();
 | |
| 
 | |
|             db.CodeFirst.InitTables<MyEntity>();
 | |
| 
 | |
|             db.Insertable(new MyEntity
 | |
|             {
 | |
|                 Id = Guid.NewGuid(),
 | |
|                 ValueObject = new MyValueObject
 | |
|                 {
 | |
|                     VoId = Guid.NewGuid(),
 | |
|                     MyEnum = MyEnum.Value1
 | |
|                 }
 | |
|             }).ExecuteCommand();
 | |
| 
 | |
|             var entity = db.Queryable<MyEntity>().First();  // 值对象中有可空的枚举属性导致查询报错
 | |
|         }
 | |
|     }
 | |
|     [SugarTable("unitadfa")]
 | |
|     public class MyEntity
 | |
|     {
 | |
|         public Guid Id { get; set; }
 | |
| 
 | |
|         [SugarColumn(IsOwnsOne = true)]
 | |
|         public MyValueObject ValueObject { get; set; }
 | |
|     }
 | |
| 
 | |
|     public enum MyEnum
 | |
|     {
 | |
|         Value1,
 | |
|         Value2
 | |
|     }
 | |
| 
 | |
|     public class MyValueObject
 | |
|     {
 | |
|         public Guid VoId { get; set; }
 | |
| 
 | |
|         [SugarColumn(IsNullable = true, ColumnDataType = "NUMBER(1, 0)")]
 | |
|         public MyEnum? MyEnum { get; set; }  // 值对象中有可空的枚举属性
 | |
|     }
 | |
|     public class UnitafasMyEntity
 | |
|     {
 | |
|         public Guid Id { get; set; }
 | |
| 
 | |
|         public string P0 { get; set; }
 | |
| 
 | |
|         public int P1 { get; set; }
 | |
| 
 | |
|         [SugarColumn(IsOwnsOne = true)]
 | |
|         public MyVO MyVO { get; set; }
 | |
|     }
 | |
| 
 | |
|     public class MyVO
 | |
|     {
 | |
|         public Guid VoId { get; set; }
 | |
| 
 | |
|         public Guid GuidP1 { get; set; }
 | |
| 
 | |
|         public Guid GuidP2 { get; set; }
 | |
|     }
 | |
|     public class UnitAddressadfafa2221
 | |
|     {
 | |
|         public string Street { get; set; }
 | |
|         public string City { get; set; }
 | |
|      
 | |
|         public string ZipCode { get; set; }
 | |
|         [SugarColumn(ColumnDataType ="VARCHAR(20)",SqlParameterDbType = typeof(EnumToStringConvert))]//CommonPropertyConvertORM自带的 
 | |
|         public DbType DbType { get; set; }
 | |
| 
 | |
|     }
 | |
|     public class UnitCustomeradfafas1
 | |
|     {
 | |
|         [SqlSugar.SugarColumn(IsPrimaryKey = true)]
 | |
|         public int CustomerId { get; set; }
 | |
|         public string Name { get; set; }
 | |
|         [SqlSugar.SugarColumn(IsOwnsOne = true)]
 | |
|         public UnitAddressadfafa2221 Address { get; set; }
 | |
|   
 | |
|     }
 | |
| }
 | 
