123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214 |
- using System;
- using System.Linq;
- using System.Text;
- using System.Data.Common;
- using System.Linq.Expressions;
- using System.Collections.Generic;
- using System.Threading.Tasks;
- using YiSha.Util;
- using YiSha.Util.Extension;
- using YiSha.Util.Model;
- using YiSha.Data;
- using YiSha.Data.Repository;
- using YiSha.Enum;
- using System.ComponentModel.DataAnnotations.Schema;
- using YiSha.Entity.SystemManage;
- using YiSha.Model.Param.SystemManage;
- using YiSha.IService.SystemManage;
- namespace YiSha.Service.SystemManage
- {
- /// <summary>
- /// 创 建:admin
- /// 日 期:2021-04-14 14:41
- /// 描 述:角色服务实现类
- /// </summary>
- public partial class RoleService : IRoleService
- {
- private DBConnectTypeEnum dbConnectType = DBConnectTypeEnum.SystemDB;
- #region 获取数据
- /// <summary>
- /// 获取列表数据
- /// </summary>
- /// <param name="param">请求参数</param>
- /// <returns></returns>
- public async Task<List<RoleEntity>> GetList(RoleListParam param)
- {
- var expression = ListFilterPartial(param);
- var list = await _baseRepository.BaseRepository(dbConnectType).FindList(expression);
- return list.ToList();
- }
- /// <summary>
- /// 获取分页数据
- /// </summary>
- /// <param name="param">请求参数</param>
- /// <param name="pagination">分页条件</param>
- /// <returns></returns>
- public async Task<List<RoleEntity>> GetPageList(RoleListParam param, Pagination pagination)
- {
- var expression = ListFilterPartial(param);
- var list = await _baseRepository.BaseRepository(dbConnectType).FindList(expression, pagination);
- return list.ToList();
- }
- /// <summary>
- /// 获取指定列数据
- /// </summary>
- /// <param name="column">表字段列</param>
- /// <param name="where">条件</param>
- /// <param name="parameters">条件参数</param>
- /// <param name="sort">排序列</param>
- /// <param name="sortType">排序类型</param>
- /// <returns></returns>
- public async Task<List<RoleEntity>> GetListColumn(string column, string where, List<DbParameter> parameters, string groupBy = "", string sort = "basecreatetime", string sortType = "desc")
- {
- if (string.IsNullOrEmpty(column) || string.IsNullOrEmpty(where))
- return new List<RoleEntity>();
- if (!string.IsNullOrEmpty(groupBy))
- groupBy = $" group by {groupBy} ";
- string tableName = typeof(RoleEntity).GetAttributeValue((TableAttribute ta) => ta.Name);
- string selectSql = $"select {column} from {tableName} where baseisdelete = @baseisdelete and {where} {groupBy} order by {sort} {sortType}";
- parameters.Add(DbParameterExtension.CreateDbParameter("@baseisdelete", (int)IsDeleteEnum.No, dbConnectType));
- var result = await _baseRepository.BaseRepository(dbConnectType).FindList<RoleEntity>(selectSql, DbParameterExtension.ToDbParameter(parameters.ToArray()));
- return result.ToList();
- }
- /// <summary>
- /// 根据主键Id获取数据
- /// </summary>
- /// <param name="id">主键id</param>
- /// <returns></returns>
- public async Task<RoleEntity> GetEntity(int id)
- {
- return await _baseRepository.BaseRepository(dbConnectType).FindEntity<RoleEntity>(id);
- }
- #endregion
- #region 提交数据
- /// <summary>
- /// 保存数据
- /// </summary>
- /// <param name="entity">实体参数</param>
- /// <returns></returns>
- public async Task SaveForm(RoleEntity entity)
- {
- if (entity.Id.IsNullOrZero())
- {
- await entity.Create();
- await _baseRepository.BaseRepository(dbConnectType).Insert(entity);
- }
- else
- {
- await entity.Modify();
- await _baseRepository.BaseRepository(dbConnectType).Update(entity);
- }
- }
- /// <summary>
- /// 保存多条数据
- /// </summary>
- /// <param name="list">数据列表</param>
- /// <returns></returns>
- public async Task<int> InsertMany(List<RoleEntity> list)
- {
- return await _baseRepository.BaseRepository(dbConnectType).Insert(list);
- }
- /// <summary>
- /// 根据主键Id删除数据
- /// </summary>
- /// <param name="ids">主键Id</param>
- /// <param name="del">是否真删除 true真删除 false软删除 默认false</param>
- /// <returns></returns>
- public async Task<int> DeleteFormById(string ids, bool del = false)
- {
- if (string.IsNullOrWhiteSpace(ids) || !ids.Split(", ").Any())
- {
- return await Task.FromResult(-1);
- }
- ids = $"{ string.Join(",", ids.Split(","))}";
- string tableName = typeof(RoleEntity).GetAttributeValue((TableAttribute ta) => ta.Name);
- string deleteSql = $"update {tableName} set baseisdelete = @baseisdelete where FIND_IN_SET (id,@id)";
- if (del)
- {
- deleteSql = $"delete from {tableName} where FIND_IN_SET (id,@id)";
- }
- List<DbParameter> parameters = new List<DbParameter>();
- parameters.Add(DbParameterExtension.CreateDbParameter("@baseisdelete", (int)IsDeleteEnum.Yes, dbConnectType));
- parameters.Add(DbParameterExtension.CreateDbParameter("@id", ids, dbConnectType));
- return await _baseRepository.BaseRepository(dbConnectType).ExecuteBySql(deleteSql, DbParameterExtension.ToDbParameter(parameters.ToArray()));
- }
- /// <summary>
- /// 根据条件删除数据
- /// </summary>
- /// <param name="where">where条件</param>
- /// <param name="parameters">参数</param>
- /// <param name="del">是否真删除 true真删除 false软删除 默认false</param>
- /// <returns></returns>
- public async Task<int> DeleteFormByWhere(string where, List<DbParameter> parameters, bool del = false)
- {
- if (string.IsNullOrWhiteSpace(where))
- {
- return await Task.FromResult(-1);
- }
- string tableName = typeof(RoleEntity).GetAttributeValue((TableAttribute ta) => ta.Name);
- string deleteSql = $"update {tableName} set baseisdelete = @baseisdelete where {where}";
- if (del)
- {
- deleteSql = $"delete from {tableName} where {where}";
- }
- parameters.Add(DbParameterExtension.CreateDbParameter("@baseisdelete", (int)IsDeleteEnum.Yes, dbConnectType));
- return await _baseRepository.BaseRepository(dbConnectType).ExecuteBySql(deleteSql, DbParameterExtension.ToDbParameter(parameters.ToArray()));
- }
- /// <summary>
- /// 修改多条数据
- /// </summary>
- /// <param name="list">数据列表</param>
- /// <returns></returns>
- public async Task<int> UpdateMany(List<RoleEntity> list)
- {
- return await _baseRepository.BaseRepository(dbConnectType).Update(list);
- }
- /// <summary>
- /// 根据条件修改数据
- /// </summary>
- /// <param name="setField">修改字段</param>
- /// <param name="where">where条件</param>
- /// <param name="parameters">参数</param>
- /// <returns></returns>
- public async Task<int> UpdateFormByWhere(string setField, string where, List<DbParameter> parameters)
- {
- if (string.IsNullOrWhiteSpace(setField) || string.IsNullOrWhiteSpace(where))
- {
- return await Task.FromResult(-1);
- }
- string tableName = typeof(RoleEntity).GetAttributeValue((TableAttribute ta) => ta.Name);
- string updateSql = $"update {tableName} set {setField} where {where}";
- return await _baseRepository.BaseRepository(dbConnectType).ExecuteBySql(updateSql, DbParameterExtension.ToDbParameter(parameters.ToArray()));
- }
- #endregion
- #region 私有方法
- ///// <summary>
- ///// 列表条件过滤
- ///// 建议该方法放在Partial部分类中,因为代码生成时当前类会被覆盖(该方法在生成时将会被注释)
- ///// </summary>
- ///// <param name="param"></param>
- ///// <returns></returns>
- //private Expression<Func<RoleEntity, bool>> ListFilter(RoleListParam param)
- //{
- // var expression = LinqExtensions.True<RoleEntity>();
- // expression = expression.And(t => t.BaseIsDelete == (int)IsDeleteEnum.No);
- // if (param != null)
- // {
- // }
- // return expression;
- //}
- #endregion
- }
- }
|