using FreeSql.DataAnnotations; using System; using System.Collections.Generic; using System.Linq; using Xunit; namespace FreeSql.Tests.Odbc.Dameng { public class DamengInsertOrUpdateTest { IFreeSql fsql => g.dameng; [Fact] public void InsertOrUpdate_OnlyPrimary() { fsql.Delete().Where("1=1").ExecuteAffrows(); var iou = fsql.InsertOrUpdate().SetSource(new tbiou01 { id = 1 }); var sql = iou.ToSql(); Assert.Equal(@"MERGE INTO ""TBIOU01"" t1 USING (SELECT 1 as ID FROM dual ) t2 ON (t1.""ID"" = t2.ID) WHEN NOT MATCHED THEN insert (""ID"") values (t2.ID)", sql); iou.ExecuteAffrows(); iou = fsql.InsertOrUpdate().SetSource(new tbiou01 { id = 1 }); sql = iou.ToSql(); Assert.Equal(@"MERGE INTO ""TBIOU01"" t1 USING (SELECT 1 as ID FROM dual ) t2 ON (t1.""ID"" = t2.ID) WHEN NOT MATCHED THEN insert (""ID"") values (t2.ID)", sql); iou.ExecuteAffrows(); iou = fsql.InsertOrUpdate().SetSource(new tbiou01 { id = 2 }); sql = iou.ToSql(); Assert.Equal(@"MERGE INTO ""TBIOU01"" t1 USING (SELECT 2 as ID FROM dual ) t2 ON (t1.""ID"" = t2.ID) WHEN NOT MATCHED THEN insert (""ID"") values (t2.ID)", sql); iou.ExecuteAffrows(); iou = fsql.InsertOrUpdate().SetSource(new[] { new tbiou01 { id = 1 }, new tbiou01 { id = 2 }, new tbiou01 { id = 3 }, new tbiou01 { id = 4 } }); sql = iou.ToSql(); Assert.Equal(@"MERGE INTO ""TBIOU01"" t1 USING (SELECT 1 as ID FROM dual UNION ALL SELECT 2 FROM dual UNION ALL SELECT 3 FROM dual UNION ALL SELECT 4 FROM dual ) t2 ON (t1.""ID"" = t2.ID) WHEN NOT MATCHED THEN insert (""ID"") values (t2.ID)", sql); iou.ExecuteAffrows(); iou = fsql.InsertOrUpdate().SetSource(new[] { new tbiou01 { id = 1 }, new tbiou01 { id = 2 }, new tbiou01 { id = 3 }, new tbiou01 { id = 4 } }); sql = iou.ToSql(); Assert.Equal(@"MERGE INTO ""TBIOU01"" t1 USING (SELECT 1 as ID FROM dual UNION ALL SELECT 2 FROM dual UNION ALL SELECT 3 FROM dual UNION ALL SELECT 4 FROM dual ) t2 ON (t1.""ID"" = t2.ID) WHEN NOT MATCHED THEN insert (""ID"") values (t2.ID)", sql); iou.ExecuteAffrows(); } class tbiou01 { public int id { get; set; } } [Fact] public void InsertOrUpdate_OnePrimary() { fsql.Delete().Where("1=1").ExecuteAffrows(); var iou = fsql.InsertOrUpdate().SetSource(new tbiou02 { id = 1, name = "01" }); var sql = iou.ToSql(); Assert.Equal(@"MERGE INTO ""TBIOU02"" t1 USING (SELECT 1 as ID, '01' as NAME FROM dual ) t2 ON (t1.""ID"" = t2.ID) WHEN MATCHED THEN update set ""NAME"" = t2.NAME WHEN NOT MATCHED THEN insert (""ID"", ""NAME"") values (t2.ID, t2.NAME)", sql); iou.ExecuteAffrows(); iou = fsql.InsertOrUpdate().SetSource(new tbiou02 { id = 1, name = "011" }); sql = iou.ToSql(); Assert.Equal(@"MERGE INTO ""TBIOU02"" t1 USING (SELECT 1 as ID, '011' as NAME FROM dual ) t2 ON (t1.""ID"" = t2.ID) WHEN MATCHED THEN update set ""NAME"" = t2.NAME WHEN NOT MATCHED THEN insert (""ID"", ""NAME"") values (t2.ID, t2.NAME)", sql); iou.ExecuteAffrows(); iou = fsql.InsertOrUpdate().SetSource(new tbiou02 { id = 2, name = "02" }); sql = iou.ToSql(); Assert.Equal(@"MERGE INTO ""TBIOU02"" t1 USING (SELECT 2 as ID, '02' as NAME FROM dual ) t2 ON (t1.""ID"" = t2.ID) WHEN MATCHED THEN update set ""NAME"" = t2.NAME WHEN NOT MATCHED THEN insert (""ID"", ""NAME"") values (t2.ID, t2.NAME)", sql); iou.ExecuteAffrows(); iou = fsql.InsertOrUpdate().SetSource(new[] { new tbiou02 { id = 1, name = "01" }, new tbiou02 { id = 2, name = "02" }, new tbiou02 { id = 3, name = "03" }, new tbiou02 { id = 4, name = "04" } }); sql = iou.ToSql(); Assert.Equal(@"MERGE INTO ""TBIOU02"" t1 USING (SELECT 1 as ID, '01' as NAME FROM dual UNION ALL SELECT 2, '02' FROM dual UNION ALL SELECT 3, '03' FROM dual UNION ALL SELECT 4, '04' FROM dual ) t2 ON (t1.""ID"" = t2.ID) WHEN MATCHED THEN update set ""NAME"" = t2.NAME WHEN NOT MATCHED THEN insert (""ID"", ""NAME"") values (t2.ID, t2.NAME)", sql); iou.ExecuteAffrows(); iou = fsql.InsertOrUpdate().SetSource(new[] { new tbiou02 { id = 1, name = "001" }, new tbiou02 { id = 2, name = "002" }, new tbiou02 { id = 3, name = "003" }, new tbiou02 { id = 4, name = "004" } }); sql = iou.ToSql(); Assert.Equal(@"MERGE INTO ""TBIOU02"" t1 USING (SELECT 1 as ID, '001' as NAME FROM dual UNION ALL SELECT 2, '002' FROM dual UNION ALL SELECT 3, '003' FROM dual UNION ALL SELECT 4, '004' FROM dual ) t2 ON (t1.""ID"" = t2.ID) WHEN MATCHED THEN update set ""NAME"" = t2.NAME WHEN NOT MATCHED THEN insert (""ID"", ""NAME"") values (t2.ID, t2.NAME)", sql); iou.ExecuteAffrows(); var lst = fsql.Select().Where(a => new[] { 1, 2, 3, 4 }.Contains(a.id)).ToList(); Assert.Equal(4, lst.Where(a => a.name == "00" + a.id).Count()); } class tbiou02 { public int id { get; set; } public string name { get; set; } } [Fact] public void InsertOrUpdate_TwoPrimary() { fsql.Delete().Where("1=1").ExecuteAffrows(); var iou = fsql.InsertOrUpdate().SetSource(new tbiou03 { id1 = 1, id2 = "01", name = "01" }); var sql = iou.ToSql(); Assert.Equal(@"MERGE INTO ""TBIOU03"" t1 USING (SELECT 1 as ID1, '01' as ID2, '01' as NAME FROM dual ) t2 ON (t1.""ID1"" = t2.ID1 AND t1.""ID2"" = t2.ID2) WHEN MATCHED THEN update set ""NAME"" = t2.NAME WHEN NOT MATCHED THEN insert (""ID1"", ""ID2"", ""NAME"") values (t2.ID1, t2.ID2, t2.NAME)", sql); iou.ExecuteAffrows(); iou = fsql.InsertOrUpdate().SetSource(new tbiou03 { id1 = 1, id2 = "02", name = "011" }); sql = iou.ToSql(); Assert.Equal(@"MERGE INTO ""TBIOU03"" t1 USING (SELECT 1 as ID1, '02' as ID2, '011' as NAME FROM dual ) t2 ON (t1.""ID1"" = t2.ID1 AND t1.""ID2"" = t2.ID2) WHEN MATCHED THEN update set ""NAME"" = t2.NAME WHEN NOT MATCHED THEN insert (""ID1"", ""ID2"", ""NAME"") values (t2.ID1, t2.ID2, t2.NAME)", sql); iou.ExecuteAffrows(); iou = fsql.InsertOrUpdate().SetSource(new tbiou03 { id1 = 2, id2 = "02", name = "02" }); sql = iou.ToSql(); Assert.Equal(@"MERGE INTO ""TBIOU03"" t1 USING (SELECT 2 as ID1, '02' as ID2, '02' as NAME FROM dual ) t2 ON (t1.""ID1"" = t2.ID1 AND t1.""ID2"" = t2.ID2) WHEN MATCHED THEN update set ""NAME"" = t2.NAME WHEN NOT MATCHED THEN insert (""ID1"", ""ID2"", ""NAME"") values (t2.ID1, t2.ID2, t2.NAME)", sql); iou.ExecuteAffrows(); iou = fsql.InsertOrUpdate().SetSource(new[] { new tbiou03 { id1 = 1, id2 = "01", name = "01" }, new tbiou03 { id1 = 2, id2 = "02", name = "02" }, new tbiou03 { id1 = 3, id2 = "03", name = "03" }, new tbiou03 { id1 = 4, id2 = "04", name = "04" } }); sql = iou.ToSql(); Assert.Equal(@"MERGE INTO ""TBIOU03"" t1 USING (SELECT 1 as ID1, '01' as ID2, '01' as NAME FROM dual UNION ALL SELECT 2, '02', '02' FROM dual UNION ALL SELECT 3, '03', '03' FROM dual UNION ALL SELECT 4, '04', '04' FROM dual ) t2 ON (t1.""ID1"" = t2.ID1 AND t1.""ID2"" = t2.ID2) WHEN MATCHED THEN update set ""NAME"" = t2.NAME WHEN NOT MATCHED THEN insert (""ID1"", ""ID2"", ""NAME"") values (t2.ID1, t2.ID2, t2.NAME)", sql); iou.ExecuteAffrows(); iou = fsql.InsertOrUpdate().SetSource(new[] { new tbiou03 { id1 = 1, id2 = "01", name = "001" }, new tbiou03 { id1 = 2, id2 = "02", name = "002" }, new tbiou03 { id1 = 3, id2 = "03", name = "003" }, new tbiou03 { id1 = 4, id2 = "04", name = "004" } }); sql = iou.ToSql(); Assert.Equal(@"MERGE INTO ""TBIOU03"" t1 USING (SELECT 1 as ID1, '01' as ID2, '001' as NAME FROM dual UNION ALL SELECT 2, '02', '002' FROM dual UNION ALL SELECT 3, '03', '003' FROM dual UNION ALL SELECT 4, '04', '004' FROM dual ) t2 ON (t1.""ID1"" = t2.ID1 AND t1.""ID2"" = t2.ID2) WHEN MATCHED THEN update set ""NAME"" = t2.NAME WHEN NOT MATCHED THEN insert (""ID1"", ""ID2"", ""NAME"") values (t2.ID1, t2.ID2, t2.NAME)", sql); iou.ExecuteAffrows(); var lst = fsql.Select().Where(a => a.id1 == 1 && a.id2 == "01" || a.id1 == 2 && a.id2 == "02" || a.id1 == 3 && a.id2 == "03" || a.id1 == 4 && a.id2 == "04").ToList(); Assert.Equal(4, lst.Where(a => a.name == "00" + a.id1).Count()); } class tbiou03 { [Column(IsPrimary = true)] public int id1 { get; set; } [Column(IsPrimary = true)] public string id2 { get; set; } public string name { get; set; } } [Fact] public void InsertOrUpdate_OnePrimaryAndVersionAndCanUpdate() { fsql.Delete().Where("1=1").ExecuteAffrows(); var iou = fsql.InsertOrUpdate().SetSource(new tbiou04 { id = 1, name = "01" }); var sql = iou.ToSql(); Assert.Equal(@"MERGE INTO ""TBIOU04"" t1 USING (SELECT 1 as ID, '01' as NAME, 0 as VERSION, systimestamp as CREATETIME FROM dual ) t2 ON (t1.""ID"" = t2.ID) WHEN MATCHED THEN update set ""NAME"" = t2.NAME, ""VERSION"" = t1.""VERSION"" + 1 WHEN NOT MATCHED THEN insert (""ID"", ""NAME"", ""VERSION"", ""CREATETIME"") values (t2.ID, t2.NAME, t2.VERSION, t2.CREATETIME)", sql); iou.ExecuteAffrows(); iou = fsql.InsertOrUpdate().SetSource(new tbiou04 { id = 1, name = "011" }); sql = iou.ToSql(); Assert.Equal(@"MERGE INTO ""TBIOU04"" t1 USING (SELECT 1 as ID, '011' as NAME, 0 as VERSION, systimestamp as CREATETIME FROM dual ) t2 ON (t1.""ID"" = t2.ID) WHEN MATCHED THEN update set ""NAME"" = t2.NAME, ""VERSION"" = t1.""VERSION"" + 1 WHEN NOT MATCHED THEN insert (""ID"", ""NAME"", ""VERSION"", ""CREATETIME"") values (t2.ID, t2.NAME, t2.VERSION, t2.CREATETIME)", sql); iou.ExecuteAffrows(); iou = fsql.InsertOrUpdate().SetSource(new tbiou04 { id = 2, name = "02" }); sql = iou.ToSql(); Assert.Equal(@"MERGE INTO ""TBIOU04"" t1 USING (SELECT 2 as ID, '02' as NAME, 0 as VERSION, systimestamp as CREATETIME FROM dual ) t2 ON (t1.""ID"" = t2.ID) WHEN MATCHED THEN update set ""NAME"" = t2.NAME, ""VERSION"" = t1.""VERSION"" + 1 WHEN NOT MATCHED THEN insert (""ID"", ""NAME"", ""VERSION"", ""CREATETIME"") values (t2.ID, t2.NAME, t2.VERSION, t2.CREATETIME)", sql); iou.ExecuteAffrows(); iou = fsql.InsertOrUpdate().SetSource(new[] { new tbiou04 { id = 1, name = "01" }, new tbiou04 { id = 2, name = "02" }, new tbiou04 { id = 3, name = "03" }, new tbiou04 { id = 4, name = "04" } }); sql = iou.ToSql(); Assert.Equal(@"MERGE INTO ""TBIOU04"" t1 USING (SELECT 1 as ID, '01' as NAME, 0 as VERSION, systimestamp as CREATETIME FROM dual UNION ALL SELECT 2, '02', 0, systimestamp FROM dual UNION ALL SELECT 3, '03', 0, systimestamp FROM dual UNION ALL SELECT 4, '04', 0, systimestamp FROM dual ) t2 ON (t1.""ID"" = t2.ID) WHEN MATCHED THEN update set ""NAME"" = t2.NAME, ""VERSION"" = t1.""VERSION"" + 1 WHEN NOT MATCHED THEN insert (""ID"", ""NAME"", ""VERSION"", ""CREATETIME"") values (t2.ID, t2.NAME, t2.VERSION, t2.CREATETIME)", sql); iou.ExecuteAffrows(); iou = fsql.InsertOrUpdate().SetSource(new[] { new tbiou04 { id = 1, name = "001" }, new tbiou04 { id = 2, name = "002" }, new tbiou04 { id = 3, name = "003" }, new tbiou04 { id = 4, name = "004" } }); sql = iou.ToSql(); Assert.Equal(@"MERGE INTO ""TBIOU04"" t1 USING (SELECT 1 as ID, '001' as NAME, 0 as VERSION, systimestamp as CREATETIME FROM dual UNION ALL SELECT 2, '002', 0, systimestamp FROM dual UNION ALL SELECT 3, '003', 0, systimestamp FROM dual UNION ALL SELECT 4, '004', 0, systimestamp FROM dual ) t2 ON (t1.""ID"" = t2.ID) WHEN MATCHED THEN update set ""NAME"" = t2.NAME, ""VERSION"" = t1.""VERSION"" + 1 WHEN NOT MATCHED THEN insert (""ID"", ""NAME"", ""VERSION"", ""CREATETIME"") values (t2.ID, t2.NAME, t2.VERSION, t2.CREATETIME)", sql); iou.ExecuteAffrows(); var lst = fsql.Select().Where(a => new[] { 1, 2, 3, 4 }.Contains(a.id)).ToList(); Assert.Equal(4, lst.Where(a => a.name == "00" + a.id).Count()); } class tbiou04 { public int id { get; set; } public string name { get; set; } [Column(IsVersion = true)] public int version { get; set; } [Column(CanUpdate = false, ServerTime = DateTimeKind.Local)] public DateTime CreateTime { get; set; } } } }