123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271 |
- using System;
- using System.Collections.Generic;
- using System.Data.Common;
- using System.Linq;
- using System.Linq.Expressions;
- using System.Text;
- using System.Threading.Tasks;
- using YiSha.Data;
- using YiSha.Data.Repository;
- using YiSha.Entity.ZX;
- using YiSha.Enum.ZX;
- using YiSha.IService.ZX;
- using YiSha.Model.Param.ZX;
- using YiSha.Model.Result.ZX;
- using YiSha.Util;
- using YiSha.Util.Extension;
- using YiSha.Util.Model;
- using YiSha.Web.Code;
- namespace YiSha.Service.ZX
- {
- /// <summary>
- /// 创 建:cmzx
- /// 日 期:2021-04-16 15:00
- /// 描 述:资讯文章服务实现类(部分类)
- /// </summary>
- public partial class NewManagerModelService
- {
- private IRepositoryFactory _baseRepository;
- private IMenuManagerModelsService _managerModelsService;
- public NewManagerModelService(IRepositoryFactory baseRepository, IMenuManagerModelsService managerModelsService)
- {
- _baseRepository = baseRepository;
- _managerModelsService = managerModelsService;
- }
- /// <summary>
- /// 获取分页数据
- /// </summary>
- /// <param name="param">请求参数</param>
- /// <param name="pagination">分页条件</param>
- /// <returns></returns>
- public async Task<List<NewManagerModelPageJoinModel>> GetPageListPartial(NewManagerModelListParam param, Pagination pagination)
- {
- var parameters = new List<DbParameter>();
- var sql = SqlPageList(param, pagination, out parameters);
- var list = await _baseRepository.BaseRepository(dbConnectType).FindList<NewManagerModelPageJoinModel>(sql, parameters.ToArray());
- return list.ToList();
- }
- /// <summary>
- /// 获取分页数据
- /// </summary>
- /// <param name="param">请求参数</param>
- /// <param name="pagination">分页条件</param>
- /// <returns></returns>
- public async Task<List<NewContentPublishNumberPageJoinModel>> GetPublishNumberPageListJson(NewContentPublishNumberListParam param, Pagination pagination)
- {
- var parameters = new List<DbParameter>();
- var sql = SqlPublishNumberPageList(param, pagination, out parameters);
- var list = await _baseRepository.BaseRepository(dbConnectType).FindList<NewContentPublishNumberPageJoinModel>(sql, parameters.ToArray());
- return list.ToList();
- }
- /// <summary>
- /// 保存数据(由于之前数据库设计不规范,无法实现在新增、修改时保存正确的操作用户信息,每张表的创建时间和创建人id、创建人姓名都不一样,且这些字段是必填项)
- /// </summary>
- /// <param name="entity">实体参数</param>
- /// <returns></returns>
- public async Task<int> SaveFormPartial(NewManagerModelEntity entity)
- {
- OperatorInfo user = await Operator.Instance.Current(entity.Token);
- if (entity.Id.IsNullOrZero())
- {
- entity.createTime = DateTime.Now;
- entity.createUserId = user?.UserId;
- entity.createUserName = user?.UserName;
- var zxId = await _baseRepository.BaseRepository(dbConnectType).Insert(entity);
- if (zxId > 0 && int.TryParse(entity.menuId?.ToString(), out var menuId))
- {
- var zxMenu = await _managerModelsService.GetEntity(menuId);
- if (int.TryParse(zxMenu?.parentId?.ToString(), out var parentId))
- {
- var type = ZxCzTemplateTypeHelper.dict[parentId];
- //描述信息
- string[] arrtributeText = type.GetEnumText();
- entity.IsGenerated = true;
- entity.SourceUrl = string.Format("/{0}/{1}.htm", arrtributeText[1] + "/" + zxMenu.Shorthand, entity.Id);
- await _baseRepository.BaseRepository(dbConnectType).Update(entity);
- }
- }
- return zxId;
- }
- else
- {
- if (int.TryParse(entity.menuId?.ToString(), out var menuId))
- {
- var zxMenu = await _managerModelsService.GetEntity(menuId);
- if (int.TryParse(zxMenu?.parentId?.ToString(), out var parentId))
- {
- var type = ZxCzTemplateTypeHelper.dict[parentId];
- //描述信息
- string[] arrtributeText = type.GetEnumText();
- entity.IsGenerated = true;
- entity.SourceUrl = string.Format("/{0}/{1}.htm", arrtributeText[1] + "/" + zxMenu.Shorthand, entity.Id);
- }
- }
- return await _baseRepository.BaseRepository(dbConnectType).Update(entity);
- }
- }
- #region 私有方法
- /// <summary>
- /// 列表条件过滤
- /// 建议该方法放在Partial部分类中,因为代码生成时当前类会被覆盖(该方法在生成时将会被注释)
- /// </summary>
- /// <param name="param"></param>
- /// <returns></returns>
- private Expression<Func<NewManagerModelEntity, bool>> ListFilterPartial(NewManagerModelListParam param)
- {
- var expression = LinqExtensions.True<NewManagerModelEntity>();
- if (param != null)
- {
- }
- return expression;
- }
- /// <summary>
- /// 获取分页Sql语句
- /// </summary>
- /// <param name="param"></param>
- /// <returns></returns>
- private string SqlPageList(NewManagerModelListParam param, Pagination pagination, out List<DbParameter> parameters)
- {
- parameters = new List<DbParameter>();
- var where = new StringBuilder();
- where.Append(" 1 = 1 ");
- if (param != null)
- {
- if (!string.IsNullOrEmpty(param.Title))
- {
- where.Append(" and nmm.title like @Title ");
- parameters.Add(DbParameterExtension.CreateDbParameter("@Title", $"%{param.Title}%", dbConnectType));
- }
- if (!string.IsNullOrEmpty(param.Qi))
- {
- where.Append(" and nmm.periodsNumber like @Qi ");
- parameters.Add(DbParameterExtension.CreateDbParameter("@Qi", $"%{param.Qi}%", dbConnectType));
- }
- if (param.MenuId != null && param.MenuId > 0)
- {
- where.Append(" and nmm.menuId = @MenuId ");
- parameters.Add(DbParameterExtension.CreateDbParameter("@MenuId", param.MenuId, dbConnectType));
- }
- var noticeMenuIds = new List<int>() { 108, 110, 111 };
- if (param.NoticeOrArticleType == MenuNoticeOrArticleTypeEnum.公告类型)
- {
- //公告类型只需要menuId为108、110、111的数据
- where.Append(" and (nmm.menuId = 108 or nmm.menuId = 110 or nmm.menuId = 111) ");
- }
- //if (!string.IsNullOrEmpty(param.MenuName))
- //{
- // where.Append(" and mmm.menuName like @MenuName ");
- // parameters.Add(DbParameterExtension.CreateDbParameter("@MenuName", $"%{param.MenuName}%", dbConnectType));
- //}
- }
- //获取分页数据Sql
- var pageSql = $@"select nmm.*,mmm.menuName,ls.labelName
- from newManagerModels nmm
- left join menuManagerModels mmm on nmm.menuId = mmm.id
- left join LabelModels ls on nmm.labelId = ls.id
- where {where.ToString()}";
- //统计总数据Sql
- var totalSql = $@"select count(1)
- from newManagerModels nmm
- left join menuManagerModels mmm on nmm.menuId = mmm.id
- left join LabelModels ls on nmm.labelId = ls.id
- where {where.ToString()}";
- pageSql = SqlserverHelper.GetInstance.SqlPageList(pageSql, totalSql, pagination);
- return pageSql;
- }
- /// <summary>
- /// 获取分页Sql语句
- /// </summary>
- /// <param name="param"></param>
- /// <returns></returns>
- private string SqlPublishNumberPageList(NewContentPublishNumberListParam param, Pagination pagination, out List<DbParameter> parameters)
- {
- parameters = new List<DbParameter>();
- var where = new StringBuilder();
- where.Append(" 1 = 1 ");
- if (param != null)
- {
- if (param.StartTime != null)
- {
- where.Append(" and nmm.createTime >= @StartTime ");
- parameters.Add(DbParameterExtension.CreateDbParameter("@StartTime", param.StartTime, dbConnectType));
- }
- if (param.EndTime != null)
- {
- where.Append(" and nmm.createTime <= @EndTime ");
- parameters.Add(DbParameterExtension.CreateDbParameter("@EndTime", param.EndTime, dbConnectType));
- }
- }
- //获取分页数据Sql
- var pageSql = string.Empty;
- //统计总数据Sql
- var totalSql = string.Empty;
- if (param.Type == PublishStatisticsType.内容发布量)
- {
- pageSql = $@"select
- 0 Id,
- nmm.menuId,
- mmm.menuName,
- nmm.createUserName userName,
- count(nmm.ID) publishNumber
- from newManagerModels nmm
- inner join menuManagerModels mmm on mmm.id = nmm.menuId
- where {where.ToString()}
- group by nmm.menuId,mmm.menuName,nmm.createUserName";
- totalSql = $@"select count(1) from
- (
- select
- count(1) as c
- from newManagerModels nmm
- inner join menuManagerModels mmm on mmm.id = nmm.menuId
- where {where.ToString()}
- group by nmm.menuId,mmm.menuName,nmm.createUserName
- ) TotalTable";
- pagination.Sort = "publishNumber";
- }
- else
- {
- pageSql = $@"select
- 0 Id,
- nmm.menuId,
- mmm.menuName,
- count(nmm.menuId) publishNumber
- from newManagerModels nmm
- inner join menuManagerModels mmm on mmm.id = nmm.menuId
- where {where.ToString()}
- group by nmm.menuId,mmm.menuName";
- totalSql = $@"select count(1) from
- (
- select
- count(1) as c
- from newManagerModels nmm
- inner join menuManagerModels mmm on mmm.id = nmm.menuId
- where {where.ToString()}
- group by nmm.menuId,mmm.menuName
- ) TotalTable";
- pagination.Sort = "publishNumber";
- }
- pageSql = SqlserverHelper.GetInstance.SqlPageList(pageSql, totalSql, pagination);
- return pageSql;
- }
- #endregion
- }
- }
|