markus / ConvertService / ServiceBase / Markus.Service.DataBase.Dapper / ConvertDatabase.cs @ master
이력 | 보기 | 이력해설 | 다운로드 (2.59 KB)
1 |
|
---|---|
2 |
using System; |
3 |
using System.Collections.Generic; |
4 |
using System.IO; |
5 |
using System.Linq; |
6 |
using System.Text; |
7 |
using System.Threading.Tasks; |
8 |
using System.Data.SqlClient; |
9 |
using Markus.Message; |
10 |
using Markus.Service.DataBase.Repositories; |
11 |
|
12 |
namespace Markus.Service.DataBase.Dapper |
13 |
{ |
14 |
public class ConvertDatabase : IDisposable |
15 |
{ |
16 |
#region Constructor |
17 |
|
18 |
public readonly string ConnectionString; |
19 |
|
20 |
public ConvertDatabase(string connectionString) |
21 |
{ |
22 |
try |
23 |
{ |
24 |
ConnectionString = connectionString; |
25 |
} |
26 |
catch (Exception ex) |
27 |
{ |
28 |
System.Diagnostics.Debug.WriteLine(ex.ToString()); |
29 |
throw ex; |
30 |
} |
31 |
} |
32 |
|
33 |
public void Dispose() |
34 |
{ |
35 |
} |
36 |
|
37 |
|
38 |
#endregion |
39 |
|
40 |
/// <summary> |
41 |
/// service에서 대기중이거나 오류인 아이템을 가져가서 컨버터 프로세스를 호출한다. |
42 |
/// 컨버터 상태가 에러이거나 2보다 작은 경우 |
43 |
/// UniqueKey는 각 데이터베이스의 문서 정보에서 유일한 키이며 컨버터저장에서 같은 폴더로의 저장을 방지 한다. |
44 |
/// |
45 |
/// </summary> |
46 |
/// <param name="aliveItems"></param> |
47 |
/// <param name="TakeCount"></param> |
48 |
/// <returns></returns> |
49 |
public async Task<IEnumerable<DataBase.Entities.ConvertDoc>> GetWaitConvertItemsAsync(int TakeCount) |
50 |
{ |
51 |
IEnumerable<DataBase.Entities.ConvertDoc> result = null; |
52 |
|
53 |
using (ConvertDocRepository repository = new ConvertDocRepository(ConnectionString)) |
54 |
{ |
55 |
result = await repository.GetWaitorErrorAsync(TakeCount); |
56 |
} |
57 |
|
58 |
return result; |
59 |
} |
60 |
|
61 |
/// <summary> |
62 |
/// 오류나 wait으로 남아 있는 데이터베이스의 Item을 StatusCodeType.None으로 복구 |
63 |
/// </summary> |
64 |
/// <param name="convertID">StatusCodeType을 변경하고자 하는 ConvertItem의 ID</param> |
65 |
/// <param name="ReConvert">ReConvert가 2이면 다시 Convert를 시도 안하기 때문에 기존 값으로 유지 하고 계속 시도 할수 있도록 0을 주는 경우가 있다.</param> |
66 |
/// <returns></returns> |
67 |
/// |
68 |
public async Task<int> SetCleanUpItemAsync(string convertID, int ReConvert) |
69 |
{ |
70 |
int result = -1; |
71 |
|
72 |
using (ConvertDocRepository repository = new ConvertDocRepository(ConnectionString)) |
73 |
{ |
74 |
result = await repository.SetCleanUpItemAsync(convertID, ReConvert); |
75 |
} |
76 |
|
77 |
return result; |
78 |
} |
79 |
|
80 |
} |
81 |
} |