using Edu.Common.Enum;
using Edu.Model.Entity.AI;
using Edu.Model.ViewModel.AI;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using VT.FW.DB.Dapper;
namespace Edu.Repository.AI
{
///
/// 调用记录仓储类
///
public class RB_AI_UseLogRepository : BaseRepository
{
///
/// 获取AI调用记录列表
///
///
///
public List GetAIUseLogList(RB_AI_UseLog_ViewModel query)
{
StringBuilder builder = new StringBuilder();
var parameters = new DynamicParameters();
builder.AppendFormat(@" SELECT A.*,b.Name as SupplierName,b.SupplierType,pa.`Name` as ApplicationName FROM RB_AI_UseLog as A left join RB_AI_Supplier as b on a.SupplierId=b.Id
left join rb_ai_presetsapplication as pa on a.ApplicationId=pa.ID
left join rb_student as c on a.StudentId= c.StuId WHERE 1=1 ");
builder.AppendFormat(" AND A.{0}={1} ", nameof(RB_AI_UseLog_ViewModel.Status), (int)DateStateEnum.Normal);
if (query != null)
{
if (query.Group_Id > 0)
{
builder.AppendFormat(" AND A.{0}={1} ", nameof(RB_AI_UseLog_ViewModel.Group_Id), query.Group_Id);
}
if (query.ID > 0)
{
builder.AppendFormat(" AND A.{0}={1} ", nameof(RB_AI_UseLog_ViewModel.ID), query.ID);
}
if (query.School_Id > 0)
{
builder.AppendFormat(" AND A.{0}={1} ", nameof(RB_AI_UseLog_ViewModel.School_Id), query.School_Id);
}
if (query.SupplierId > 0)
{
builder.AppendFormat(" AND A.{0}={1} ", nameof(RB_AI_UseLog_ViewModel.SupplierId), query.SupplierId);
}
if (query.StudentId > 0)
{
builder.AppendFormat(" AND A.{0}={1} ", nameof(RB_AI_UseLog_ViewModel.StudentId), query.StudentId);
}
}
return Get(builder.ToString(), parameters).ToList();
}
///
/// 获取AI调用记录分页列表
///
///
///
public List GetAIUseLogPageList(int pageIndex, int pageSize, out long rowsCount, RB_AI_UseLog_ViewModel query)
{
StringBuilder builder = new StringBuilder();
var parameters = new DynamicParameters();
builder.AppendFormat(@"SELECT A.*,b.Name as SupplierName,b.SupplierType,pa.`Name` as ApplicationName FROM RB_AI_UseLog as A left join RB_AI_Supplier as b on a.SupplierId=b.Id
left join rb_ai_presetsapplication as pa on a.ApplicationId=pa.ID
left join rb_student as c on a.StudentId= c.StuId WHERE 1=1 ");
builder.AppendFormat(" AND A.{0}={1} ", nameof(RB_AI_UseLog_ViewModel.Status), (int)DateStateEnum.Normal);
if (query != null)
{
if (query.Group_Id > 0)
{
builder.AppendFormat(" AND A.{0}={1} ", nameof(RB_AI_UseLog_ViewModel.Group_Id), query.Group_Id);
}
if (query.ID > 0)
{
builder.AppendFormat(" AND A.{0}={1} ", nameof(RB_AI_UseLog_ViewModel.ID), query.ID);
}
if (query.School_Id > 0)
{
builder.AppendFormat(" AND A.{0}={1} ", nameof(RB_AI_UseLog_ViewModel.School_Id), query.School_Id);
}
if (query.SupplierId > 0)
{
builder.AppendFormat(" AND A.{0}={1} ", nameof(RB_AI_UseLog_ViewModel.SupplierId), query.SupplierId);
}
if (query.StudentId > 0)
{
builder.AppendFormat(" AND A.{0}={1} ", nameof(RB_AI_UseLog_ViewModel.StudentId), query.StudentId);
}
if (!string.IsNullOrEmpty(query.StartDate))
{
builder.AppendFormat(@" AND A.{0}>='{1}' ", nameof(RB_AI_UseLog_ViewModel.CreateTime), query.StartDate);
}
if (!string.IsNullOrEmpty(query.EndDate))
{
builder.AppendFormat(@" AND A.{0}<='{1} 23:59:59' ", nameof(RB_AI_UseLog_ViewModel.CreateTime), query.EndDate);
}
}
builder.AppendFormat(" order by A.CreateTime desc");
return GetPage(pageIndex, pageSize, out rowsCount, builder.ToString(), parameters).ToList();
}
}
}