Skip to content

Commit

Permalink
Sqlsugar 分表 CRUD demo
Browse files Browse the repository at this point in the history
  • Loading branch information
Jamnine committed Mar 30, 2023
1 parent d1288b1 commit 67efee3
Show file tree
Hide file tree
Showing 13 changed files with 642 additions and 3 deletions.
44 changes: 44 additions & 0 deletions Blog.Core.Api/Blog.Core.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

199 changes: 199 additions & 0 deletions Blog.Core.Api/Controllers/SplitDemoController.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,199 @@
using Blog.Core.IServices;
using Blog.Core.Model;
using Blog.Core.Model.Models;
using Blog.Core.Repository.UnitOfWorks;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
using System.Linq.Expressions;

namespace Blog.Core.Api.Controllers
{
/// <summary>
/// 分表demo
/// </summary>
[Route("api/[controller]/[action]")]
[ApiController]
[Authorize(Permissions.Name)]
public class SplitDemoController : ControllerBase
{
readonly ISplitDemoServices splitDemoServices;
readonly IUnitOfWorkManage unitOfWorkManage;
public SplitDemoController(ISplitDemoServices _splitDemoServices, IUnitOfWorkManage _unitOfWorkManage)
{
splitDemoServices = _splitDemoServices;
unitOfWorkManage = _unitOfWorkManage;
}

/// <summary>
/// 分页获取数据
/// </summary>
/// <param name="beginTime"></param>
/// <param name="endTime"></param>
/// <param name="page"></param>
/// <param name="key"></param>
/// <param name="pageSize"></param>
/// <returns></returns>
[HttpGet]
[AllowAnonymous]
public async Task<MessageModel<PageModel<SplitDemo>>> Get(DateTime beginTime, DateTime endTime, int page = 1, string key = "", int pageSize = 10)
{
if (string.IsNullOrEmpty(key) || string.IsNullOrWhiteSpace(key))
{
key = "";
}
Expression<Func<SplitDemo, bool>> whereExpression = a => (a.Name != null && a.Name.Contains(key));
var data = await splitDemoServices.QueryPageSplit(whereExpression, beginTime, endTime, page, pageSize, " Id desc ");
return MessageModel<PageModel<SplitDemo>>.Message(data.dataCount >= 0, "获取成功", data);
}

/// <summary>
/// 根据ID获取信息
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
[HttpGet]
[AllowAnonymous]
public async Task<MessageModel<SplitDemo>> GetById(long id)
{
var data = new MessageModel<string>();
var model = await splitDemoServices.QueryByIdSplit(id);
if (model != null)
{
return MessageModel<SplitDemo>.Success("获取成功", model);
}
else
{
return MessageModel<SplitDemo>.Fail("获取失败");
}
}

/// <summary>
/// 添加一条测试数据
/// </summary>
/// <param name="splitDemo"></param>
/// <returns></returns>
[HttpPost]
[AllowAnonymous]
public async Task<MessageModel<string>> Post([FromBody] SplitDemo splitDemo)
{
var data = new MessageModel<string>();
unitOfWorkManage.BeginTran();
var id = (await splitDemoServices.AddSplit(splitDemo));
data.success = (id == null ? false : true);
try
{
if (data.success)
{
data.response = id.FirstOrDefault().ToString();
data.msg = "添加成功";
}
else
{
data.msg = "添加失败";
}
}
catch (Exception)
{
throw;
}
finally
{
if (data.success)
unitOfWorkManage.CommitTran();
else
unitOfWorkManage.RollbackTran();
}
return data;
}

/// <summary>
/// 修改一条测试数据
/// </summary>
/// <param name="splitDemo"></param>
/// <returns></returns>
[HttpPut]
[AllowAnonymous]
public async Task<MessageModel<string>> Put([FromBody] SplitDemo splitDemo)
{
var data = new MessageModel<string>();
if (splitDemo != null && splitDemo.Id > 0)
{
unitOfWorkManage.BeginTran();
data.success = await splitDemoServices.UpdateSplit(splitDemo, splitDemo.CreateTime);
try
{
if (data.success)
{
data.msg = "修改成功";
data.response = splitDemo?.Id.ObjToString();
}
else
{
data.msg = "修改失败";
}
}
catch (Exception)
{
throw;
}
finally
{
if (data.success)
unitOfWorkManage.CommitTran();
else
unitOfWorkManage.RollbackTran();
}
}
return data;
}

/// <summary>
/// 根据id删除数据
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
[HttpDelete]
[AllowAnonymous]
public async Task<MessageModel<string>> Delete(long id)
{
var data = new MessageModel<string>();

var model = await splitDemoServices.QueryByIdSplit(id);
if (model != null)
{
unitOfWorkManage.BeginTran();
data.success = await splitDemoServices.DeleteSplit(model,model.CreateTime);
try
{
data.response = id.ObjToString();
if (data.success)
{
data.msg = "删除成功";
}
else
{
data.msg = "删除失败";
}

}
catch (Exception)
{
throw;
}
finally
{
if (data.success)
unitOfWorkManage.CommitTran();
else
unitOfWorkManage.RollbackTran();
}
}
else
{
data.msg = "不存在";
}
return data;

}
}
}
4 changes: 4 additions & 0 deletions Blog.Core.Api/Program.cs
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,15 @@
using Blog.Core;
using Blog.Core.Common;
using Blog.Core.Common.Core;
using Blog.Core.Common.Helper;
using Blog.Core.Common.LogHelper;
using Blog.Core.Extensions;
using Blog.Core.Extensions.Apollo;
using Blog.Core.Extensions.Middlewares;
using Blog.Core.Filter;
using Blog.Core.Hubs;
using Blog.Core.IServices;
using Blog.Core.Model;
using Blog.Core.Tasks;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.Controllers;
Expand Down Expand Up @@ -111,6 +113,8 @@
//options.SerializerSettings.NullValueHandling = NullValueHandling.Ignore;
options.SerializerSettings.DateTimeZoneHandling = DateTimeZoneHandling.Local;
options.SerializerSettings.Converters.Add(new StringEnumConverter());
//将long类型转为string
options.SerializerSettings.Converters.Add(new NumberConverter(NumberConverterShip.Int64));
})
//.AddFluentValidation(config =>
//{
Expand Down
4 changes: 4 additions & 0 deletions Blog.Core.Api/Startup.cs
Original file line number Diff line number Diff line change
Expand Up @@ -3,13 +3,15 @@
using System.Text;
using Autofac;
using Blog.Core.Common;
using Blog.Core.Common.Helper;
using Blog.Core.Common.LogHelper;
using Blog.Core.Common.Seed;
using Blog.Core.Extensions;
using Blog.Core.Extensions.Middlewares;
using Blog.Core.Filter;
using Blog.Core.Hubs;
using Blog.Core.IServices;
using Blog.Core.Model;
using Blog.Core.Tasks;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.Controllers;
Expand Down Expand Up @@ -123,6 +125,8 @@ public void ConfigureServices(IServiceCollection services)
options.SerializerSettings.DateTimeZoneHandling = DateTimeZoneHandling.Local;
//添加Enum转string
options.SerializerSettings.Converters.Add(new StringEnumConverter());
//将long类型转为string
options.SerializerSettings.Converters.Add(new NumberConverter(NumberConverterShip.Int64));
});

services.Replace(ServiceDescriptor.Transient<IControllerActivator, ServiceBasedControllerActivator>());
Expand Down
Loading

0 comments on commit 67efee3

Please sign in to comment.