You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
75 lines
2.6 KiB
75 lines
2.6 KiB
using OrmTest.Models;
|
|
using OrmTest.UnitTest;
|
|
using SqlSugar;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Text;
|
|
using System.Threading.Tasks;
|
|
|
|
namespace OrmTest
|
|
{
|
|
public class Delete : UnitTestBase
|
|
{
|
|
private Delete() { }
|
|
public Delete(int eachCount)
|
|
{
|
|
this.Count = eachCount;
|
|
}
|
|
|
|
public void Init()
|
|
{
|
|
var db = GetInstance();
|
|
//by entity
|
|
var t1= db.Deleteable<Student>().Where(new Student() { Id = 1 }).ToSql();
|
|
base.Check(@"DELETE FROM [STudent] WHERE [Id] IN ('1') ",
|
|
null,
|
|
t1.Key,
|
|
null, "Delte t1 error"
|
|
);
|
|
//use lock
|
|
var t2 = db.Deleteable<Student>().With(SqlWith.RowLock).ToSql();
|
|
base.Check(@"DELETE FROM [STudent] WITH(ROWLOCK) ",
|
|
null,
|
|
t2.Key,
|
|
null, "Delte t2 error"
|
|
);
|
|
|
|
//by primary key
|
|
var t3 = db.Deleteable<Student>().In(1).ToSql();
|
|
base.Check(@"DELETE FROM [STudent] WHERE [Id] IN ('1') ",
|
|
null,
|
|
t3.Key,
|
|
null, "Delte tt error"
|
|
);
|
|
//by primary key array
|
|
var t4 = db.Deleteable<Student>().In(new int[] { 1,2}).ToSql();
|
|
base.Check(@"DELETE FROM [STudent] WHERE [Id] IN ('1','2') ", null, t4.Key, null, "Update t4 error");
|
|
|
|
//by expression
|
|
var t5 = db.Deleteable<Student>().Where(it=>it.Id==1).ToSql();
|
|
base.Check(@"DELETE FROM [STudent] WHERE ( [ID] = @Id0 ) ", new List<SugarParameter>() {
|
|
new SugarParameter("@Id0",1)
|
|
}, t5.Key, t5.Value, "Delte t5 error");
|
|
|
|
var t6 = db.Deleteable<Student>().Where("id=@id",new { id=1}).ToSql();
|
|
base.Check(@"DELETE FROM [STudent] WHERE id=@id", new List<SugarParameter>() {
|
|
new SugarParameter("@id",1)
|
|
}, t6.Key, t6.Value, "Delte t6 error");
|
|
|
|
var t7 = base.GetInstanceByAttribute().Deleteable<DeleteTestTable>().Where(new List<DeleteTestTable>() {
|
|
new DeleteTestTable() { Id=1, Id2="x" },
|
|
new DeleteTestTable() { Id=2, Id2="x1" }
|
|
}).ToSql();
|
|
base.Check("DELETE FROM [DeleteTestTable] WHERE (([Id]=N'1'AND [Id2]=N'x')OR ([Id]=N'2'AND [Id2]=N'x1')) ",null, t7.Key, null,
|
|
"Delte t7 error");
|
|
}
|
|
}
|
|
|
|
public class DeleteTestTable {
|
|
[SugarColumn(IsPrimaryKey =true)]
|
|
public int Id { get; set; }
|
|
[SugarColumn(IsPrimaryKey = true)]
|
|
public string Id2 { get; set; }
|
|
}
|
|
}
|