45 lines
1.7 KiB
C#
45 lines
1.7 KiB
C#
using Longbow;
|
|
using Longbow.Cache;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Data;
|
|
using System.Data.Common;
|
|
|
|
namespace Bootstrap.DataAccess.SQLite
|
|
{
|
|
public class Task : DataAccess.Task
|
|
{
|
|
/// <summary>
|
|
/// 查询所有任务
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
public override IEnumerable<DataAccess.Task> RetrieveTasks()
|
|
{
|
|
return CacheManager.GetOrAdd(RetrieveTasksDataKey, key =>
|
|
{
|
|
string sql = "select t.*, u.DisplayName from Tasks t inner join Users u on t.UserName = u.UserName order by AssignTime desc limit 1000";
|
|
List<Task> tasks = new List<Task>();
|
|
DbCommand cmd = DbAccessManager.DBAccess.CreateCommand(CommandType.Text, sql);
|
|
using (DbDataReader reader = DbAccessManager.DBAccess.ExecuteReader(cmd))
|
|
{
|
|
while (reader.Read())
|
|
{
|
|
tasks.Add(new Task()
|
|
{
|
|
Id = LgbConvert.ReadValue(reader[0], 0),
|
|
TaskName = (string)reader[1],
|
|
AssignName = (string)reader[2],
|
|
UserName = (string)reader[3],
|
|
TaskTime = LgbConvert.ReadValue(reader[4], 0),
|
|
TaskProgress = (double)reader[5],
|
|
AssignTime = LgbConvert.ReadValue(reader[6], DateTime.MinValue),
|
|
AssignDisplayName = (string)reader[7]
|
|
});
|
|
}
|
|
}
|
|
return tasks;
|
|
});
|
|
}
|
|
}
|
|
}
|