mirror of
https://github.com/nsnail/FreeSql.git
synced 2025-04-17 00:12:50 +08:00
423 lines
19 KiB
C#
423 lines
19 KiB
C#
using FreeSql.DataAnnotations;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using Xunit;
|
|
|
|
namespace FreeSql.Tests.Odbc.SqlServer
|
|
{
|
|
public class SqlServerInsertOrUpdateIfExistsDoNothingTest
|
|
{
|
|
IFreeSql fsql => g.sqlserver;
|
|
|
|
[Fact]
|
|
public void InsertOrUpdate_OnlyPrimary()
|
|
{
|
|
fsql.Delete<tbioudb01>().Where("1=1").ExecuteAffrows();
|
|
var iou = fsql.InsertOrUpdate<tbioudb01>().IfExistsDoNothing().SetSource(new tbioudb01 { id = 1 });
|
|
var sql = iou.ToSql();
|
|
Assert.Equal(@"MERGE INTO [tbioudb01] t1
|
|
USING (SELECT 1 as [id] ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id])
|
|
values (t2.[id]);", sql);
|
|
Assert.Equal(1, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb01>().IfExistsDoNothing().SetSource(new tbioudb01 { id = 1 });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"MERGE INTO [tbioudb01] t1
|
|
USING (SELECT 1 as [id] ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id])
|
|
values (t2.[id]);", sql);
|
|
Assert.Equal(0, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb01>().IfExistsDoNothing().SetSource(new tbioudb01 { id = 2 });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"MERGE INTO [tbioudb01] t1
|
|
USING (SELECT 2 as [id] ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id])
|
|
values (t2.[id]);", sql);
|
|
Assert.Equal(1, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb01>().IfExistsDoNothing().SetSource(new[] { new tbioudb01 { id = 1 }, new tbioudb01 { id = 2 }, new tbioudb01 { id = 3 }, new tbioudb01 { id = 4 } });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"MERGE INTO [tbioudb01] t1
|
|
USING (SELECT 1 as [id]
|
|
UNION ALL
|
|
SELECT 2
|
|
UNION ALL
|
|
SELECT 3
|
|
UNION ALL
|
|
SELECT 4 ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id])
|
|
values (t2.[id]);", sql);
|
|
Assert.Equal(2, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb01>().IfExistsDoNothing().SetSource(new[] { new tbioudb01 { id = 1 }, new tbioudb01 { id = 2 }, new tbioudb01 { id = 3 }, new tbioudb01 { id = 4 } });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"MERGE INTO [tbioudb01] t1
|
|
USING (SELECT 1 as [id]
|
|
UNION ALL
|
|
SELECT 2
|
|
UNION ALL
|
|
SELECT 3
|
|
UNION ALL
|
|
SELECT 4 ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id])
|
|
values (t2.[id]);", sql);
|
|
Assert.Equal(0, iou.ExecuteAffrows());
|
|
}
|
|
class tbioudb01
|
|
{
|
|
public int id { get; set; }
|
|
}
|
|
|
|
[Fact]
|
|
public void InsertOrUpdate_OnePrimary()
|
|
{
|
|
fsql.Delete<tbioudb02>().Where("1=1").ExecuteAffrows();
|
|
var iou = fsql.InsertOrUpdate<tbioudb02>().IfExistsDoNothing().SetSource(new tbioudb02 { id = 1, name = "01" });
|
|
var sql = iou.ToSql();
|
|
Assert.Equal(@"MERGE INTO [tbioudb02] t1
|
|
USING (SELECT 1 as [id], N'01' as [name] ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id], [name])
|
|
values (t2.[id], t2.[name]);", sql);
|
|
Assert.Equal(1, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb02>().IfExistsDoNothing().SetSource(new tbioudb02 { id = 1, name = "011" });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"MERGE INTO [tbioudb02] t1
|
|
USING (SELECT 1 as [id], N'011' as [name] ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id], [name])
|
|
values (t2.[id], t2.[name]);", sql);
|
|
Assert.Equal(0, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb02>().IfExistsDoNothing().SetSource(new tbioudb02 { id = 2, name = "02" });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"MERGE INTO [tbioudb02] t1
|
|
USING (SELECT 2 as [id], N'02' as [name] ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id], [name])
|
|
values (t2.[id], t2.[name]);", sql);
|
|
Assert.Equal(1, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb02>().IfExistsDoNothing().SetSource(new[] { new tbioudb02 { id = 1, name = "01" }, new tbioudb02 { id = 2, name = "02" }, new tbioudb02 { id = 3, name = "03" }, new tbioudb02 { id = 4, name = "04" } });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"MERGE INTO [tbioudb02] t1
|
|
USING (SELECT 1 as [id], N'01' as [name]
|
|
UNION ALL
|
|
SELECT 2, N'02'
|
|
UNION ALL
|
|
SELECT 3, N'03'
|
|
UNION ALL
|
|
SELECT 4, N'04' ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id], [name])
|
|
values (t2.[id], t2.[name]);", sql);
|
|
Assert.Equal(2, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb02>().IfExistsDoNothing().SetSource(new[] { new tbioudb02 { id = 1, name = "001" }, new tbioudb02 { id = 2, name = "002" }, new tbioudb02 { id = 3, name = "003" }, new tbioudb02 { id = 4, name = "004" } });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"MERGE INTO [tbioudb02] t1
|
|
USING (SELECT 1 as [id], N'001' as [name]
|
|
UNION ALL
|
|
SELECT 2, N'002'
|
|
UNION ALL
|
|
SELECT 3, N'003'
|
|
UNION ALL
|
|
SELECT 4, N'004' ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id], [name])
|
|
values (t2.[id], t2.[name]);", sql);
|
|
Assert.Equal(0, iou.ExecuteAffrows());
|
|
var lst = fsql.Select<tbioudb02>().Where(a => new[] { 1, 2, 3, 4 }.Contains(a.id)).ToList();
|
|
Assert.Equal(4, lst.Where(a => a.name == "0" + a.id).Count());
|
|
}
|
|
class tbioudb02
|
|
{
|
|
public int id { get; set; }
|
|
public string name { get; set; }
|
|
}
|
|
[Fact]
|
|
public void InsertOrUpdate_OnePrimaryAndIdentity()
|
|
{
|
|
fsql.Delete<tbioudb022>().Where("1=1").ExecuteAffrows();
|
|
var iou = fsql.InsertOrUpdate<tbioudb022>().IfExistsDoNothing().SetSource(new tbioudb022 { id = 1, name = "01" });
|
|
var sql = iou.ToSql();
|
|
Assert.Equal(@"SET IDENTITY_INSERT [tbioudb022] ON;
|
|
MERGE INTO [tbioudb022] t1
|
|
USING (SELECT 1 as [id], N'01' as [name] ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id], [name])
|
|
values (t2.[id], t2.[name]);;
|
|
SET IDENTITY_INSERT [tbioudb022] OFF;", sql);
|
|
Assert.Equal(1, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb022>().IfExistsDoNothing().SetSource(new tbioudb022 { id = 1, name = "011" });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"SET IDENTITY_INSERT [tbioudb022] ON;
|
|
MERGE INTO [tbioudb022] t1
|
|
USING (SELECT 1 as [id], N'011' as [name] ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id], [name])
|
|
values (t2.[id], t2.[name]);;
|
|
SET IDENTITY_INSERT [tbioudb022] OFF;", sql);
|
|
Assert.Equal(0, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb022>().IfExistsDoNothing().SetSource(new tbioudb022 { id = 2, name = "02" });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"SET IDENTITY_INSERT [tbioudb022] ON;
|
|
MERGE INTO [tbioudb022] t1
|
|
USING (SELECT 2 as [id], N'02' as [name] ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id], [name])
|
|
values (t2.[id], t2.[name]);;
|
|
SET IDENTITY_INSERT [tbioudb022] OFF;", sql);
|
|
Assert.Equal(1, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb022>().IfExistsDoNothing().SetSource(new[] { new tbioudb022 { id = 1, name = "01" }, new tbioudb022 { id = 2, name = "02" }, new tbioudb022 { id = 3, name = "03" }, new tbioudb022 { id = 4, name = "04" } });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"SET IDENTITY_INSERT [tbioudb022] ON;
|
|
MERGE INTO [tbioudb022] t1
|
|
USING (SELECT 1 as [id], N'01' as [name]
|
|
UNION ALL
|
|
SELECT 2, N'02'
|
|
UNION ALL
|
|
SELECT 3, N'03'
|
|
UNION ALL
|
|
SELECT 4, N'04' ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id], [name])
|
|
values (t2.[id], t2.[name]);;
|
|
SET IDENTITY_INSERT [tbioudb022] OFF;", sql);
|
|
Assert.Equal(2, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb022>().IfExistsDoNothing().SetSource(new[] { new tbioudb022 { id = 1, name = "001" }, new tbioudb022 { id = 2, name = "002" }, new tbioudb022 { id = 3, name = "003" }, new tbioudb022 { id = 4, name = "004" } });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"SET IDENTITY_INSERT [tbioudb022] ON;
|
|
MERGE INTO [tbioudb022] t1
|
|
USING (SELECT 1 as [id], N'001' as [name]
|
|
UNION ALL
|
|
SELECT 2, N'002'
|
|
UNION ALL
|
|
SELECT 3, N'003'
|
|
UNION ALL
|
|
SELECT 4, N'004' ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id], [name])
|
|
values (t2.[id], t2.[name]);;
|
|
SET IDENTITY_INSERT [tbioudb022] OFF;", sql);
|
|
Assert.Equal(0, iou.ExecuteAffrows());
|
|
var lst = fsql.Select<tbioudb022>().Where(a => new[] { 1, 2, 3, 4 }.Contains(a.id)).ToList();
|
|
Assert.Equal(4, lst.Where(a => a.name == "0" + a.id).Count());
|
|
|
|
//--no primary
|
|
iou = fsql.InsertOrUpdate<tbioudb022>().IfExistsDoNothing().SetSource(new tbioudb022 { name = "01" });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"INSERT INTO [tbioudb022]([name]) VALUES(N'01')", sql);
|
|
Assert.Equal(1, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb022>().IfExistsDoNothing().SetSource(new tbioudb022 { name = "011" });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"INSERT INTO [tbioudb022]([name]) VALUES(N'011')", sql);
|
|
Assert.Equal(1, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb022>().IfExistsDoNothing().SetSource(new tbioudb022 { name = "02" });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"INSERT INTO [tbioudb022]([name]) VALUES(N'02')", sql);
|
|
Assert.Equal(1, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb022>().IfExistsDoNothing().SetSource(new[] { new tbioudb022 { name = "01" }, new tbioudb022 { name = "02" }, new tbioudb022 { name = "03" }, new tbioudb022 { name = "04" } });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"INSERT INTO [tbioudb022]([name]) VALUES(N'01'), (N'02'), (N'03'), (N'04')", sql);
|
|
Assert.Equal(4, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb022>().IfExistsDoNothing().SetSource(new[] { new tbioudb022 { name = "001" }, new tbioudb022 { name = "002" }, new tbioudb022 { name = "003" }, new tbioudb022 { name = "004" } });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"INSERT INTO [tbioudb022]([name]) VALUES(N'001'), (N'002'), (N'003'), (N'004')", sql);
|
|
Assert.Equal(4, iou.ExecuteAffrows());
|
|
|
|
//--no primary and yes
|
|
iou = fsql.InsertOrUpdate<tbioudb022>().IfExistsDoNothing().SetSource(new[] { new tbioudb022 { id = 1, name = "100001" }, new tbioudb022 { name = "00001" }, new tbioudb022 { id = 2, name = "100002" }, new tbioudb022 { name = "00002" }, new tbioudb022 { id = 3, name = "100003" }, new tbioudb022 { name = "00003" }, new tbioudb022 { id = 4, name = "100004" }, new tbioudb022 { name = "00004" } });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"SET IDENTITY_INSERT [tbioudb022] ON;
|
|
MERGE INTO [tbioudb022] t1
|
|
USING (SELECT 1 as [id], N'100001' as [name]
|
|
UNION ALL
|
|
SELECT 2, N'100002'
|
|
UNION ALL
|
|
SELECT 3, N'100003'
|
|
UNION ALL
|
|
SELECT 4, N'100004' ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id], [name])
|
|
values (t2.[id], t2.[name]);;
|
|
SET IDENTITY_INSERT [tbioudb022] OFF;
|
|
|
|
;
|
|
|
|
INSERT INTO [tbioudb022]([name]) VALUES(N'00001'), (N'00002'), (N'00003'), (N'00004')", sql);
|
|
Assert.Equal(4, iou.ExecuteAffrows());
|
|
lst = fsql.Select<tbioudb022>().Where(a => new[] { 1, 2, 3, 4 }.Contains(a.id)).ToList();
|
|
Assert.Equal(4, lst.Where(a => a.name == "0" + a.id).Count());
|
|
}
|
|
class tbioudb022
|
|
{
|
|
[Column(IsIdentity = true)]
|
|
public int id { get; set; }
|
|
public string name { get; set; }
|
|
}
|
|
|
|
[Fact]
|
|
public void InsertOrUpdate_TwoPrimary()
|
|
{
|
|
fsql.Delete<tbioudb03>().Where("1=1").ExecuteAffrows();
|
|
var iou = fsql.InsertOrUpdate<tbioudb03>().IfExistsDoNothing().SetSource(new tbioudb03 { id1 = 1, id2 = "01", name = "01" });
|
|
var sql = iou.ToSql();
|
|
Assert.Equal(@"MERGE INTO [tbioudb03] t1
|
|
USING (SELECT 1 as [id1], N'01' as [id2], N'01' as [name] ) t2 ON (t1.[id1] = t2.[id1] AND t1.[id2] = t2.[id2])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id1], [id2], [name])
|
|
values (t2.[id1], t2.[id2], t2.[name]);", sql);
|
|
Assert.Equal(1, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb03>().IfExistsDoNothing().SetSource(new tbioudb03 { id1 = 1, id2 = "01", name = "011" });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"MERGE INTO [tbioudb03] t1
|
|
USING (SELECT 1 as [id1], N'01' as [id2], N'011' as [name] ) t2 ON (t1.[id1] = t2.[id1] AND t1.[id2] = t2.[id2])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id1], [id2], [name])
|
|
values (t2.[id1], t2.[id2], t2.[name]);", sql);
|
|
Assert.Equal(0, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb03>().IfExistsDoNothing().SetSource(new tbioudb03 { id1 = 2, id2 = "02", name = "02" });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"MERGE INTO [tbioudb03] t1
|
|
USING (SELECT 2 as [id1], N'02' as [id2], N'02' as [name] ) t2 ON (t1.[id1] = t2.[id1] AND t1.[id2] = t2.[id2])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id1], [id2], [name])
|
|
values (t2.[id1], t2.[id2], t2.[name]);", sql);
|
|
Assert.Equal(1, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb03>().IfExistsDoNothing().SetSource(new[] { new tbioudb03 { id1 = 1, id2 = "01", name = "01" }, new tbioudb03 { id1 = 2, id2 = "02", name = "02" }, new tbioudb03 { id1 = 3, id2 = "03", name = "03" }, new tbioudb03 { id1 = 4, id2 = "04", name = "04" } });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"MERGE INTO [tbioudb03] t1
|
|
USING (SELECT 1 as [id1], N'01' as [id2], N'01' as [name]
|
|
UNION ALL
|
|
SELECT 2, N'02', N'02'
|
|
UNION ALL
|
|
SELECT 3, N'03', N'03'
|
|
UNION ALL
|
|
SELECT 4, N'04', N'04' ) t2 ON (t1.[id1] = t2.[id1] AND t1.[id2] = t2.[id2])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id1], [id2], [name])
|
|
values (t2.[id1], t2.[id2], t2.[name]);", sql);
|
|
Assert.Equal(2, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb03>().IfExistsDoNothing().SetSource(new[] { new tbioudb03 { id1 = 1, id2 = "01", name = "001" }, new tbioudb03 { id1 = 2, id2 = "02", name = "002" }, new tbioudb03 { id1 = 3, id2 = "03", name = "003" }, new tbioudb03 { id1 = 4, id2 = "04", name = "004" } });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"MERGE INTO [tbioudb03] t1
|
|
USING (SELECT 1 as [id1], N'01' as [id2], N'001' as [name]
|
|
UNION ALL
|
|
SELECT 2, N'02', N'002'
|
|
UNION ALL
|
|
SELECT 3, N'03', N'003'
|
|
UNION ALL
|
|
SELECT 4, N'04', N'004' ) t2 ON (t1.[id1] = t2.[id1] AND t1.[id2] = t2.[id2])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id1], [id2], [name])
|
|
values (t2.[id1], t2.[id2], t2.[name]);", sql);
|
|
Assert.Equal(0, iou.ExecuteAffrows());
|
|
var lst = fsql.Select<tbioudb03>().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 == "0" + a.id1).Count());
|
|
}
|
|
class tbioudb03
|
|
{
|
|
[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<tbioudb04>().Where("1=1").ExecuteAffrows();
|
|
var iou = fsql.InsertOrUpdate<tbioudb04>().IfExistsDoNothing().SetSource(new tbioudb04 { id = 1, name = "01" });
|
|
var sql = iou.ToSql();
|
|
Assert.Equal(@"MERGE INTO [tbioudb04] t1
|
|
USING (SELECT 1 as [id], N'01' as [name], 0 as [version], getdate() as [CreateTime] ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id], [name], [version], [CreateTime])
|
|
values (t2.[id], t2.[name], t2.[version], t2.[CreateTime]);", sql);
|
|
Assert.Equal(1, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb04>().IfExistsDoNothing().SetSource(new tbioudb04 { id = 1, name = "011" });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"MERGE INTO [tbioudb04] t1
|
|
USING (SELECT 1 as [id], N'011' as [name], 0 as [version], getdate() as [CreateTime] ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id], [name], [version], [CreateTime])
|
|
values (t2.[id], t2.[name], t2.[version], t2.[CreateTime]);", sql);
|
|
Assert.Equal(0, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb04>().IfExistsDoNothing().SetSource(new tbioudb04 { id = 2, name = "02" });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"MERGE INTO [tbioudb04] t1
|
|
USING (SELECT 2 as [id], N'02' as [name], 0 as [version], getdate() as [CreateTime] ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id], [name], [version], [CreateTime])
|
|
values (t2.[id], t2.[name], t2.[version], t2.[CreateTime]);", sql);
|
|
Assert.Equal(1, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb04>().IfExistsDoNothing().SetSource(new[] { new tbioudb04 { id = 1, name = "01" }, new tbioudb04 { id = 2, name = "02" }, new tbioudb04 { id = 3, name = "03" }, new tbioudb04 { id = 4, name = "04" } });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"MERGE INTO [tbioudb04] t1
|
|
USING (SELECT 1 as [id], N'01' as [name], 0 as [version], getdate() as [CreateTime]
|
|
UNION ALL
|
|
SELECT 2, N'02', 0, getdate()
|
|
UNION ALL
|
|
SELECT 3, N'03', 0, getdate()
|
|
UNION ALL
|
|
SELECT 4, N'04', 0, getdate() ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id], [name], [version], [CreateTime])
|
|
values (t2.[id], t2.[name], t2.[version], t2.[CreateTime]);", sql);
|
|
Assert.Equal(2, iou.ExecuteAffrows());
|
|
|
|
iou = fsql.InsertOrUpdate<tbioudb04>().IfExistsDoNothing().SetSource(new[] { new tbioudb04 { id = 1, name = "001" }, new tbioudb04 { id = 2, name = "002" }, new tbioudb04 { id = 3, name = "003" }, new tbioudb04 { id = 4, name = "004" } });
|
|
sql = iou.ToSql();
|
|
Assert.Equal(@"MERGE INTO [tbioudb04] t1
|
|
USING (SELECT 1 as [id], N'001' as [name], 0 as [version], getdate() as [CreateTime]
|
|
UNION ALL
|
|
SELECT 2, N'002', 0, getdate()
|
|
UNION ALL
|
|
SELECT 3, N'003', 0, getdate()
|
|
UNION ALL
|
|
SELECT 4, N'004', 0, getdate() ) t2 ON (t1.[id] = t2.[id])
|
|
WHEN NOT MATCHED THEN
|
|
insert ([id], [name], [version], [CreateTime])
|
|
values (t2.[id], t2.[name], t2.[version], t2.[CreateTime]);", sql);
|
|
Assert.Equal(0, iou.ExecuteAffrows());
|
|
var lst = fsql.Select<tbioudb04>().Where(a => new[] { 1, 2, 3, 4 }.Contains(a.id)).ToList();
|
|
Assert.Equal(4, lst.Where(a => a.name == "0" + a.id).Count());
|
|
}
|
|
class tbioudb04
|
|
{
|
|
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; }
|
|
}
|
|
}
|
|
}
|