SqlSugar/Src/Asp.NetCore2/MySqlTest/UserTestCases/UnitTest/UJson.cs
2024-04-29 11:43:41 +08:00

62 lines
2.5 KiB
C#

using Newtonsoft.Json.Linq;
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace OrmTest
{
public partial class NewUnitTest
{
public static void Json()
{
Db.CodeFirst.InitTables<UnitJsonTest>();
Db.DbMaintenance.TruncateTable<UnitJsonTest>();
Db.Insertable(new UnitJsonTest() { Order = new Order { Id = 1, Name = "order1" } }).ExecuteCommand();
var list = Db.Queryable<UnitJsonTest>().ToList();
UValidate.Check("order1", list.First().Order.Name, "Json");
Db.Updateable(new UnitJsonTest() { Id = 1, Order = new Order { Id = 2, Name = "order2" } }).ExecuteCommand();
list = Db.Queryable<UnitJsonTest>().ToList();
UValidate.Check("order2", list.First().Order.Name, "Json");
Db.Updateable<UnitJsonTest>().SetColumns(x => new UnitJsonTest { Order = new Order { Id = 2, Name = "order3" } }).Where(x => x.Id == 1).ExecuteCommand();
list = Db.Queryable<UnitJsonTest>().ToList();
UValidate.Check("order3", list.First().Order.Name, "Json");
var list2 = Db.Queryable<UnitJsonTest>().ToList();
Db.CodeFirst.InitTables<UnitJsonTest123123>();
Db.Insertable(new UnitJsonTest123123() {
Order = JObject.Parse(Db.Utilities.SerializeObject(new { x = new { y = 100 } }))
}).ExecuteCommand();
var list3 = Db.Queryable<UnitJsonTest123123>().Select(it => new {
x = SqlFunc.JsonField(it.Order, "x")
}).ToList();
var list31 = Db.Queryable<UnitJsonTest123123>().Select(it => new {
x = SqlFunc.JsonField(SqlFunc.JsonField(it.Order, "x" ),"y")
}).ToList();
var list32 = Db.Queryable<UnitJsonTest123123>().Select(it=>new {
x=SqlFunc.JsonField(it.Order, "x","y")
}).ToList();
}
}
public class UnitJsonTest123123
{
[SqlSugar.SugarColumn(IsPrimaryKey = true, IsIdentity = true)]
public int Id { get; set; }
[SqlSugar.SugarColumn(ColumnDataType = "varchar(4000)", IsJson = true)]
public JObject Order { get; set; }
}
public class UnitJsonTest
{
[SqlSugar.SugarColumn(IsPrimaryKey = true, IsIdentity = true)]
public int Id { get; set; }
[SqlSugar.SugarColumn(ColumnDataType = "varchar(4000)", IsJson = true)]
public Order Order { get; set; }
}
}