using Edu.Common.Enum; using Edu.Model.ViewModel.Course; using System.Collections.Generic; using System.Linq; using System.Text; using VT.FW.DB.Dapper; namespace Edu.Repository.Course { /// /// 课程仓储层 /// public class RB_CourseRepository : BaseRepository { /// /// 获取课程列表 /// /// /// public List GetCourseListRepository(RB_Course_ViewModel query) { var parameters = new DynamicParameters(); StringBuilder builder = new StringBuilder(); builder.AppendFormat(@" SELECT A.*,IFNULL(B.CateName,'') AS CateName FROM RB_Course AS A LEFT JOIN rb_course_category AS B ON A.CateId=B.CateId WHERE 1=1 "); builder.AppendFormat(" AND A.{0}={1} ", nameof(RB_Course_ViewModel.Group_Id), query.Group_Id); builder.AppendFormat(" AND A.{0}={1} ", nameof(RB_Course_ViewModel.Status), (int)DateStateEnum.Normal); if (query != null) { if (!string.IsNullOrWhiteSpace(query.CourseName)) { builder.AppendFormat(" AND A.{0} LIKE @CourseName ", nameof(RB_Course_ViewModel.CourseName)); parameters.Add("CourseName", "%" + query.CourseName.Trim() + "%"); } if (query.CateId > 0) { builder.AppendFormat(" AND A.{0}={1} ", nameof(RB_Course_ViewModel.CateId), query.CateId); } if (!string.IsNullOrEmpty(query.QCourseIds)) { builder.AppendFormat(" AND A.{0} IN({1}) ", nameof(RB_Course_ViewModel.CourseId), query.QCourseIds); } //取随机前几条 if (query.IsRand && query.RandNum > 0 && query.CourseId > 0) { builder.AppendFormat(" AND A.{0}<>{1} ORDER BY RAND() LIMIT {2} ", nameof(RB_Course_ViewModel.CourseId), query.CourseId, query.RandNum); } //销售平台 if (!string.IsNullOrEmpty(query.Saleplat)) { var salePlatList = Common.ConvertHelper.StringToList(query.Saleplat); string str = ""; if (salePlatList != null && salePlatList.Count > 0) { for (var i = 0; i < salePlatList.Count; i++) { if (i == 0) { str += string.Format(" FIND_IN_SET('{0}', A.Saleplat)>0 ", salePlatList[i]); } else { str += string.Format(" AND FIND_IN_SET('{0}', A.Saleplat)>0 ", salePlatList[i]); } } } if (!string.IsNullOrEmpty(str)) { builder.AppendFormat(" AND ({0}) ", str); } } } return Get(builder.ToString(), parameters).ToList(); } /// /// 获取课程分页列表 /// /// /// /// /// /// public List GetCoursePageListRepository(int pageIndex, int pageSize, out long rowsCount, RB_Course_ViewModel query) { var parameters = new DynamicParameters(); StringBuilder builder = new StringBuilder(); builder.AppendFormat(@" SELECT A.*,IFNULL(B.CateName,'') AS CateName FROM RB_Course AS A LEFT JOIN rb_course_category AS B ON A.CateId=B.CateId WHERE 1=1 "); builder.AppendFormat(" AND A.{0}={1} ", nameof(RB_Course_ViewModel.Group_Id), query.Group_Id); //builder.AppendFormat(" AND A.{0}={1} ", nameof(RB_Course_ViewModel.School_Id), query.School_Id); if (query != null) { if ((int)query.Status > -1) { builder.AppendFormat(" AND A.{0}={1} ", nameof(RB_Course_ViewModel.Status), (int)query.Status); } if (!string.IsNullOrWhiteSpace(query.CourseName)) { builder.AppendFormat(" AND A.{0} LIKE @CourseName ", nameof(RB_Course_ViewModel.CourseName)); parameters.Add("CourseName", "%" + query.CourseName.Trim() + "%"); } if (query.CateId > 0) { builder.AppendFormat(" AND A.{0}={1} ", nameof(RB_Course_ViewModel.CateId), query.CateId); } if (!string.IsNullOrWhiteSpace(query.QCateIds)) { builder.AppendFormat(" AND A.{0} IN({1}) ", nameof(RB_Course_ViewModel.CateId), query.QCateIds); } //销售平台 if (!string.IsNullOrEmpty(query.Saleplat)) { var salePlatList = Common.ConvertHelper.StringToList(query.Saleplat); string str = ""; if (salePlatList != null && salePlatList.Count > 0) { for (var i = 0; i < salePlatList.Count; i++) { if (i == 0) { str += string.Format(" FIND_IN_SET('{0}', A.Saleplat)>0 ", salePlatList[i]); } else { str += string.Format(" AND FIND_IN_SET('{0}', A.Saleplat)>0 ", salePlatList[i]); } } } if (!string.IsNullOrEmpty(str)) { builder.AppendFormat(" AND ({0}) ", str); } } } return GetPage(pageIndex, pageSize, out rowsCount, builder.ToString(), parameters).ToList(); } } }