프로젝트

일반

사용자정보

통계
| 개정판:

hytos / ID2.Manager / ID2.Manager.Dapper / Repository / DocumentRepository.cs @ 42d4c228

이력 | 보기 | 이력해설 | 다운로드 (24.7 KB)

1
using System;
2
using System.Collections.Generic;
3
using System.Linq;
4
using System.Text;
5
using System.Threading.Tasks;
6

    
7
using System.Data;
8

    
9
using ID2.Manager.Data.Models;
10

    
11
using Dapper;
12
using System.ComponentModel;
13
using System.Reflection;
14

    
15
namespace ID2.Manager.Dapper.Repository
16
{
17
    public class DocumentRepository : BaseRepository
18
    {
19
        public DocumentRepository(string connectionStr) : base(connectionStr) { }
20

    
21
        public IEnumerable<Documents> GetAllDocuments(string projectGroupID)
22
        {
23
            var dynamicParameters = new DynamicParameters();
24
            StringBuilder sbWhere = new StringBuilder();
25
            var parameters = new Dictionary<string, object>();
26
            if (!string.IsNullOrEmpty(projectGroupID))
27
            {
28
                sbWhere.Append(" and doc.RefProjectCode in (select Code from dbo.Projects where ParentID=@RefGroupID) ");
29
                parameters.Add("RefGroupID", projectGroupID);
30
            }
31

    
32
            try
33
            {
34
                string query = $@"
35
select   doc.*
36
from     dbo.Documents doc
37
where    doc.IsDeleted=0 {sbWhere}
38
order by doc.Seq;";
39

    
40
                if (parameters.Count > 0)
41
                {
42
                    dynamicParameters.AddDynamicParams(parameters);
43
                }
44

    
45
                return Query<Documents>(query, dynamicParameters);
46
            }
47
            catch (Exception ex)
48
            {
49
                throw ex;
50
            }
51
        }
52
        static string GetDescriptionFromAttribute(MemberInfo member)
53
        {
54
            if (member == null) return null;
55

    
56
            var attrib = (DescriptionAttribute)Attribute.GetCustomAttribute(member, typeof(DescriptionAttribute), false);
57
            return (attrib?.Description ?? member.Name).ToLower();
58
        }
59

    
60

    
61
        public (IEnumerable<Documents> dwgs, int totalCnt) GetDocuments(string projectGroupID, List<string> dateTypes, DateTime? frDate, DateTime? toDate, string projectCode, string personIncharge, string jobLevel, string documentNo, string isToIsDiscussion, string isFrReviewStatus, string isID2Work, string id2Status, string id2Issues, string avevaStatus, string avevaIssues, string prodIsResult, string clientIsResult, string isGateWay, string isRegSystem)
62
        {
63
            var map = new CustomPropertyTypeMap(typeof(AttFileInfo), (type, columnName)
64
     => type.GetProperties().FirstOrDefault(prop => GetDescriptionFromAttribute(prop) == columnName.ToLower()));
65
            SqlMapper.SetTypeMap(typeof(AttFileInfo), map);
66

    
67

    
68
            var dynamicParameters = new DynamicParameters();
69
            dynamicParameters.Add("Total", dbType: DbType.Int32, direction: ParameterDirection.Output);
70

    
71
            StringBuilder sbWhere = new StringBuilder();
72
            StringBuilder sbTotalWhere = new StringBuilder();
73
            var parameters = new Dictionary<string, object>();
74
            if (dateTypes.Count > 0 && (frDate != null || toDate != null))
75
            {
76
                List<string> subWheres = new List<string>();
77
                foreach (string dateType in dateTypes)
78
                {
79
                    StringBuilder sbSubWhere = new StringBuilder();
80
                    if (frDate != null)
81
                    {
82
                        sbSubWhere.Insert(0, $@"convert(datetime, '{Convert.ToDateTime(frDate).AddDays(-1):yyyy-MM-dd 23:59:59.997}') < doc.{dateType}");
83
                    }
84
                    if (toDate != null)
85
                    {
86
                        if (frDate != null)
87
                            sbSubWhere.Append($@" and ");
88
                        sbSubWhere.Append($@"doc.{dateType} < convert(datetime, '{Convert.ToDateTime(toDate).AddDays(1):yyyy-MM-dd 00:00:00.000}')");
89
                    }
90

    
91
                    if (sbSubWhere.Length > 0)
92
                    {
93
                        subWheres.Add("(" + sbSubWhere.ToString() + ")");
94
                    }
95
                }
96

    
97
                if (subWheres.Count > 0)
98
                {
99
                    sbWhere.Append(" and (" + string.Join(" or ", subWheres) + ") ");
100
                }
101
            }
102
            if (string.IsNullOrEmpty(projectCode))
103
            {
104
                sbWhere.Append(" and isnull(doc.RefProjectCode,'') in (select Code from dbo.Projects where ParentID=@RefGroupID union all select '') ");
105
                sbTotalWhere.Append(" and isnull(doc.RefProjectCode,'') in (select Code from dbo.Projects where ParentID=@RefGroupID union all select '') ");
106
                parameters.Add("RefGroupID", projectGroupID);
107
            }
108
            else
109
            {
110
                sbTotalWhere.Append(" and isnull(doc.RefProjectCode,'') in (select Code from dbo.Projects where ParentID=@RefGroupID union all select '') ");
111
                parameters.Add("RefGroupID", projectGroupID);
112

    
113
                sbWhere.Append(" and doc.RefProjectCode=@RefProjectCode ");
114
                parameters.Add("RefProjectCode", projectCode);
115
            }
116
            if (!string.IsNullOrEmpty(personIncharge))
117
            {
118
                sbWhere.Append(" and doc.PersonInCharge=@PersonInCharge ");
119
                parameters.Add("PersonInCharge", personIncharge);
120
            }
121
            if (!string.IsNullOrEmpty(jobLevel))
122
            {
123
                sbWhere.Append(" and doc.JobLevel=@JobLevel ");
124
                parameters.Add("JobLevel", jobLevel);
125
            }
126
            if (!string.IsNullOrEmpty(documentNo))
127
            {
128
                sbWhere.Append(" and doc.DocumentNo like '%' + @DocumentNo +'%' ");
129
                parameters.Add("DocumentNo", documentNo);
130
            }
131

    
132
            if (!string.IsNullOrEmpty(isToIsDiscussion))
133
            {
134
                sbWhere.Append(" and doc.ToIsDiscussion=@ToIsDiscussion ");
135
                parameters.Add("ToIsDiscussion", isToIsDiscussion);
136
            }
137

    
138
            if (!string.IsNullOrEmpty(isFrReviewStatus))
139
            {
140
                sbWhere.Append(" and doc.FrReviewStatus=@FrReviewStatus ");
141
                parameters.Add("FrReviewStatus", isFrReviewStatus);
142
            }
143

    
144
            if (!string.IsNullOrEmpty(isID2Work))
145
            {
146
                sbWhere.Append(" and doc.IsID2Work=@IsID2Work ");
147
                parameters.Add("IsID2Work", isID2Work);
148
            }
149

    
150
            if (!string.IsNullOrEmpty(id2Status))
151
            {
152
                sbWhere.Append(" and doc.ID2Status=@ID2Status ");
153
                parameters.Add("ID2Status", id2Status);
154
            }
155

    
156
            if (!string.IsNullOrEmpty(id2Issues))
157
            {
158
                sbWhere.Append(" and (case when isnull(ltrim(rtrim(doc.ID2Issues)),'') = '' then 'No' else 'Yes' end)=@ID2Issues ");
159
                parameters.Add("ID2Issues", id2Issues);
160
            }
161
            
162
            if (!string.IsNullOrEmpty(avevaStatus))
163
            {
164
                sbWhere.Append(" and doc.AVEVAStatus=@AVEVAStatus ");
165
                parameters.Add("AVEVAStatus", avevaStatus);
166
            }
167

    
168
            if (!string.IsNullOrEmpty(avevaIssues))
169
            {
170
                sbWhere.Append(" and (case when isnull(ltrim(rtrim(doc.AVEVAIssues)),'') = '' then 'No' else 'Yes' end)=@AVEVAIssues ");
171
                parameters.Add("AVEVAIssues", avevaIssues);
172
            }
173

    
174
            if (!string.IsNullOrEmpty(prodIsResult))
175
            {
176
                sbWhere.Append(" and doc.ProdIsResult=@ProdIsResult ");
177
                parameters.Add("ProdIsResult", prodIsResult);
178
            }
179
            if (!string.IsNullOrEmpty(clientIsResult))
180
            {
181
                sbWhere.Append(" and doc.ClientIsResult=@ClientIsResult ");
182
                parameters.Add("ClientIsResult", clientIsResult);
183
            }
184
            if (!string.IsNullOrEmpty(isGateWay))
185
            {
186
                sbWhere.Append(" and doc.DTIsGateWay=@DTIsGateWay ");
187
                parameters.Add("DTIsGateWay", isGateWay);
188
            }
189
            if (!string.IsNullOrEmpty(isRegSystem))
190
            {
191
                sbWhere.Append(" and doc.DTIsRegSystem=@DTIsRegSystem ");
192
                parameters.Add("DTIsRegSystem", isRegSystem);
193
            }
194

    
195
            try
196
            {
197

    
198
                //files.[FileID],files.[FileID] as AttFileID, files.RefID, files.Category, files.FileType, files.FileName, files.FilePath, files.FileExtension, files.FileData, files.Remark, files.CreatedDate, files.Creator,
199
                    string query = $@"
200
                            select  doc.*, datediff(SECOND, doc.ID2StartDate, doc.ID2EndDate) as ID2JobTime,
201
                            files.[FileID] as FileID, files.*,
202
                            markus.MARKUP_DATA_ID as MARKUP_DATA_ID, markus.*
203
                            from     dbo.Documents doc
204
	                        LEFT OUTER JOIN AttachFIles files ON doc.DocID = fIles.RefID 
205
                            LEFT OUTER JOIN 
206
                                    (SELECT [MARKUP_DATA_ID]
207
                                           ,[PROJECT_NO] as PROJECT_NO
208
                                          ,[DOCUMENT_ID] as DocumentNo
209
                                          
210
                                          ,[PAGENUMBER]
211
                                          ,[Text] as TEXT
212
                                          ,[CREATE_DATE] as CREATE_DATE
213
                                          ,[NAME] as CREATE_USER
214
                                      FROM ViewMarkupData) markus 
215
                            ON doc.DocumentNo = markus.DocumentNo
216
                            where    doc.IsDeleted=0 {sbWhere}
217
                            order by doc.Seq
218

    
219
select @Total=count(*) from dbo.Documents doc where doc.IsDeleted=0 {sbTotalWhere}
220
select @Total;";
221

    
222
                if (parameters.Count > 0)
223
                {
224
                    dynamicParameters.AddDynamicParams(parameters);
225
                }
226

    
227
                var docDictionary = new Dictionary<string, Documents>();
228

    
229
                var ret = MultiQuery<Documents, AttFileInfo, MarkupText, Documents>(query,
230
                                (document, attfile, markusText) =>
231
                                {
232
                                    Documents doc;
233

    
234
                                    if (!docDictionary.TryGetValue(document.DocID, out doc))
235
                                    {
236
                                        doc = document;
237
                                        docDictionary.Add(doc.DocID, doc);
238
                                    }
239

    
240
                                    if (markusText != null)
241
                                    {
242
                                        doc.Markups = doc.Markups ?? new List<MarkupText>();
243

    
244
                                        if (!doc.Markups.Any(x => x.MARKUP_DATA_ID == markusText.MARKUP_DATA_ID))
245
                                        {
246
                                            doc.Markups.Add(markusText);
247
                                        }
248
                                    }
249

    
250
                                    if (attfile != null)
251
                                    {
252
                                        doc.AttFiles = doc.AttFiles ?? new List<AttFileInfo>();
253
                                        System.Diagnostics.Debug.WriteLine(attfile.FileName);
254
                                        if (!doc.AttFiles.Any(x => x.FileID == attfile.FileID))
255
                                        {
256
                                            switch (attfile.Category)
257
                                            {
258
                                                case "toreview":
259
                                                    doc.ToCapture++;
260
                                                    break;
261
                                                case "frreview":
262
                                                    doc.FrCapture++;
263
                                                    break;
264
                                                case "prodvalidation":
265
                                                    doc.ProdCapture++;
266
                                                    break;
267
                                                case "clientvalidation":
268
                                                    doc.ClientCapture++;
269
                                                    break;
270
                                            }
271

    
272
                                            doc.AttFiles.Add(attfile);
273
                                        }
274
                                    }
275

    
276
                                    return doc;
277

    
278
                                }, dynamicParameters, splitOn: "DocID,FileID,MARKUP_DATA_ID").Distinct();
279

    
280
                int totalCount = dynamicParameters.Get<int>("Total");
281

    
282
                return (ret, totalCount);
283
            }
284
            catch (Exception ex)
285
            {
286
                throw ex;
287
            }
288
        }
289

    
290
        public int ExistsDocument(string projectGroupID, List<string> newDwgNos)
291
        {
292
            var dynamicParameters = new DynamicParameters();
293
            StringBuilder sbWhere = new StringBuilder();
294
            var parameters = new Dictionary<string, object>();
295
            if (!string.IsNullOrEmpty(projectGroupID))
296
            {
297
                sbWhere.Append(" and doc.RefProjectCode in (select Code from dbo.Projects where ParentID=@RefGroupID) ");
298
                parameters.Add("RefGroupID", projectGroupID);
299
            }
300

    
301
            if (newDwgNos.Count > 0)
302
            {
303
                string dwgNoList = string.Join("','", newDwgNos.Where(x => !string.IsNullOrEmpty(x)).Select(x => x).ToList());
304

    
305
                if (dwgNoList.Length > 0)
306
                {
307
                    if (!string.IsNullOrEmpty(projectGroupID))
308
                    {
309
                        sbWhere.Append($@" and doc.DocumentNo in ('{dwgNoList}') ");
310
                    }
311
                }
312
            }
313

    
314
            try
315
            {
316
                string query = $@"
317
select   count(*) cnt
318
from     dbo.Documents doc
319
where    doc.IsDeleted=0 {sbWhere}";
320

    
321
                if (parameters.Count > 0)
322
                {
323
                    dynamicParameters.AddDynamicParams(parameters);
324
                }
325

    
326
                return ExecuteScalar<int>(query, dynamicParameters);
327
            }
328
            catch (Exception ex)
329
            {
330
                throw ex;
331
            }
332
        }
333

    
334
        public bool SetDocumentData(List<Documents> docList, List<Documents> delDocList, string userId)
335
        {
336
            bool isSuccess = false;
337

    
338
            try
339
            {
340
                using (var transaction = base.BeginTransaction())
341
                {
342
                    string query = string.Empty;
343

    
344
                    if (delDocList.Count > 0)
345
                    {
346
                        string docIDList = string.Join("','", delDocList.Where(x => !string.IsNullOrEmpty(x.DocID)).Select(x => x.DocID).ToList());
347

    
348
                        if (docIDList.Length > 0)
349
                        {
350
                            query = $@"
351
update dbo.Documents
352
set    IsDeleted=1
353
      ,DeletedDate=getdate(),
354
      ,DeletedUser=@DeletedUser
355
where  DocID in ('{docIDList}');";
356
                            base.Execute(query, new { DeletedUser = userId }, transaction);
357
                        }
358
                    }
359

    
360
                    foreach (Documents doc in docList)
361
                    {
362
                        if (string.IsNullOrEmpty(doc.DocID))
363
                        {
364
                            doc.RegisteredUser = userId;
365
                            query = $@"
366
declare @tbdoc table(docid varchar(36))
367
insert into dbo.Documents
368
(
369
     DocID
370
    ,DocumentNo
371
    ,RevisonNo
372
    ,RefProjectCode
373
    ,JobLevel
374
    ,IsTypical
375
    ,PersonInCharge
376
    ,RegisteredDate
377
    ,RegisteredUser
378
    ,ToIsDiscussion
379
    ,ToRemarks
380
    ,ToCreator
381
    ,ToIsMarkup
382
    ,FrReviewStatus
383
    ,FrRemarks
384
    ,FrCreator
385
    ,FrIsMarkup
386
    ,IsID2Work
387
    ,ID2Connection
388
    ,ID2StartDate
389
    ,ID2EndDate
390
    ,ID2Status
391
    ,ID2Issues
392
    ,AVEVAConnection
393
    ,AVEVAConvertDate
394
    ,AVEVAReviewDate
395
    ,AVEVAStatus
396
    ,AVEVAIssues
397
    ,ReviewFilePath
398
    ,ReviewFileName
399
    ,ProdReviewer
400
    ,ProdIsResult
401
    ,ProdRemarks
402
    ,ClientReviewer
403
    ,ClientIsResult
404
    ,ClientRemarks
405
    ,DTIsGateWay
406
    ,DTIsImport
407
    ,DTIsRegSystem
408
    ,DTRemarks
409
)
410
output inserted.DocID into @tbdoc
411
values 
412
(
413
     lower(newid())
414
    ,@DocumentNo
415
    ,@RevisonNo
416
    ,@RefProjectCode
417
    ,@JobLevel
418
    ,@IsTypical
419
    ,@PersonInCharge
420
    ,getdate()
421
    ,@RegisteredUser
422
    ,@ToIsDiscussion
423
    ,@ToRemarks
424
    ,@ToCreator
425
    ,@ToIsMarkup
426
    ,@FrReviewStatus
427
    ,@FrRemarks
428
    ,@FrCreator
429
    ,@FrIsMarkup
430
    ,@IsID2Work
431
    ,@ID2Connection
432
    ,@ID2StartDate
433
    ,@ID2EndDate
434
    ,@ID2Status
435
    ,@ID2Issues
436
    ,@AVEVAConnection
437
    ,@AVEVAConvertDate
438
    ,@AVEVAReviewDate
439
    ,@AVEVAStatus
440
    ,@AVEVAIssues
441
    ,@ReviewFilePath
442
    ,@ReviewFileName
443
    ,@ProdReviewer
444
    ,@ProdIsResult
445
    ,@ProdRemarks
446
    ,@ClientReviewer
447
    ,@ClientIsResult
448
    ,@ClientRemarks
449
    ,@DTIsGateWay
450
    ,@DTIsImport
451
    ,@DTIsRegSystem
452
    ,@DTRemarks
453
)
454

    
455
if @@rowcount > 0
456
begin
457
    select docid from @tbdoc
458
end
459
else
460
begin
461
    select ''
462
end;";
463
                        }
464
                        else
465
                        {
466
                            doc.ModifiedUser = userId;
467
                            query = $@"
468
update dbo.Documents
469
set    DocumentNo=@DocumentNo
470
      ,RevisonNo=@RevisonNo
471
      ,RefProjectCode=@RefProjectCode
472
      ,JobLevel=@JobLevel
473
      ,IsTypical=@IsTypical
474
      ,PersonInCharge=@PersonInCharge
475
      ,ModifiedDate=getdate()
476
      ,ModifiedUser=@ModifiedUser
477
      ,ToIsDiscussion=@ToIsDiscussion
478
      ,ToRemarks=@ToRemarks
479
      ,ToCreator=@ToCreator
480
      ,ToIsMarkup=@ToIsMarkup
481
      ,FrReviewStatus=@FrReviewStatus
482
      ,FrRemarks=@FrRemarks
483
      ,FrCreator=@FrCreator
484
      ,FrIsMarkup=@FrIsMarkup
485
      ,IsID2Work=@IsID2Work
486
      ,ID2Connection=@ID2Connection
487
      ,ID2StartDate=@ID2StartDate
488
      ,ID2EndDate=@ID2EndDate
489
      ,ID2Status=@ID2Status
490
      ,ID2Issues=@ID2Issues
491
      ,AVEVAConnection=@AVEVAConnection
492
      ,AVEVAConvertDate=@AVEVAConvertDate
493
      ,AVEVAReviewDate=@AVEVAReviewDate
494
      ,AVEVAStatus=@AVEVAStatus
495
      ,AVEVAIssues=@AVEVAIssues
496
      ,ReviewFilePath=@ReviewFilePath
497
      ,ReviewFileName=@ReviewFileName
498
      ,ProdReviewer=@ProdReviewer
499
      ,ProdIsResult=@ProdIsResult
500
      ,ProdRemarks=@ProdRemarks
501
      ,ClientReviewer=@ClientReviewer
502
      ,ClientIsResult=@ClientIsResult
503
      ,ClientRemarks=@ClientRemarks
504
      ,DTIsGateWay=@DTIsGateWay
505
      ,DTIsImport=@DTIsImport
506
      ,DTIsRegSystem=@DTIsRegSystem
507
      ,DTRemarks=@DTRemarks
508
where  DocID=@DocID
509

    
510
if @@rowcount > 0
511
begin
512
    select @DocID
513
end
514
else
515
begin
516
    select ''
517
end;";
518
                        }
519
                        string refID = base.QueryFirstOrDefault<string>(query, doc, transaction);
520

    
521
                        if (doc.AttFiles != null && doc.AttFiles.Count > 0)
522
                        {
523
                            string attDelIDList = string.Join("','", doc.AttFiles.Where(x => !string.IsNullOrEmpty(x.FileID)).Select(x => x.FileID).ToList());
524

    
525
                            if (!string.IsNullOrEmpty(refID) && attDelIDList.Length > 0)
526
                            {
527
                                query = $@"
528
delete from dbo.AttachFIles
529
where  RefID=@RefID and FileID in ('{attDelIDList}');";
530
                                base.Execute(query, new { RefID = refID }, transaction);
531
                            }
532

    
533
                            foreach (AttFileInfo attFile in doc.AttFiles)
534
                            {
535
                                if (string.IsNullOrEmpty(attFile.RefID))
536
                                {
537
                                    attFile.RefID = refID;
538
                                    attFile.Creator = userId;
539

    
540
                                    query = $@"
541
insert into dbo.AttachFIles (FileID,RefID,Category,FileType,FileName,FilePath,FileExtension,FileData,Creator)
542
values
543
(
544
    lower(newid())
545
   ,@RefID
546
   ,@Category
547
   ,@FileType
548
   ,@FileName
549
   ,@FilePath
550
   ,@FileExtension
551
   ,@FileData
552
   ,@Creator
553
)";
554

    
555
                                    base.Execute(query, attFile, transaction);
556
                                }
557
                            }
558
                        }
559
                    }
560

    
561
                    transaction.Commit();
562
                    isSuccess = true;
563
                }
564
            }
565
            catch (Exception ex)
566
            {
567
                throw ex;
568
            }
569

    
570
            return isSuccess;
571
        }
572

    
573
        public Documents SetDocumentDataField(Documents doc, string userId)
574
        {
575
            Documents resultData = null;
576

    
577
            try
578
            {
579
                using (var transaction = base.BeginTransaction())
580
                {
581
                    string query = string.Empty;
582

    
583
                    if (!string.IsNullOrEmpty(doc.DocID))
584
                    {
585
                        StringBuilder sbSet = new StringBuilder();
586
                        var parameters = new Dictionary<string, object>();
587

    
588
                        #region Update 할 목록
589
                        if (doc.ID2StartDate != null)
590
                        {
591
                            sbSet.Append(" ,ID2StartDate=(case when ID2StartDate is null then @DateTimeNow else ID2StartDate end) ");
592
                            parameters.Add("ID2StartDate", doc.ID2StartDate);
593
                        }
594

    
595
                        if (doc.Worker != null)
596
                        {
597
                            sbSet.Append(" ,Worker=@Worker ");
598
                            parameters.Add("Worker", doc.Worker);
599
                        }
600
                        #endregion
601

    
602
                        if (parameters.Count > 0)
603
                        {
604
                            sbSet.Append(" ,ModifiedUser=@ModifiedUser ");
605
                            parameters.Add("ModifiedUser", userId);
606

    
607
                            parameters.Add("DocID", doc.DocID);
608

    
609
                            query = $@"
610
declare @DateTimeNow datetime
611
set @DateTimeNow = getdate()
612

    
613
update dbo.Documents
614
set    ModifiedDate=@DateTimeNow {sbSet}
615
where  [DocID]=@DocID
616

    
617
if @@rowcount > 0
618
begin
619
    select *, datediff(SECOND, ID2StartDate, ID2EndDate) as ID2JobTime from dbo.Documents where DocID=@DocID
620
end
621
else
622
begin
623
    select *, 0 as ID2JobTime from dbo.Documents where 1=2
624
end;";
625
                            resultData = base.QueryFirstOrDefault<Documents>(query, parameters, transaction);
626
                        }
627
                    }
628

    
629
                    transaction.Commit();
630
                }
631
            }
632
            catch (Exception ex)
633
            {
634
                throw ex;
635
            }
636

    
637
            return resultData;
638
        }
639

    
640
        public bool SetDocumentDatasField(List<Documents> docs, string userId)
641
        {
642
            bool isSuccess = false;
643

    
644
            try
645
            {
646
                using (var transaction = base.BeginTransaction())
647
                {
648
                    foreach (Documents doc in docs)
649
                    {
650
                        string query = string.Empty;
651

    
652
                        if (!string.IsNullOrEmpty(doc.DocID))
653
                        {
654
                            StringBuilder sbSet = new StringBuilder();
655
                            var parameters = new Dictionary<string, object>();
656

    
657
                            #region Update 할 목록
658
                            if (doc.ID2EndDate != null)
659
                            {
660
                                sbSet.Append(" ,ID2EndDate=@ID2EndDate ");
661
                                parameters.Add("ID2EndDate", doc.ID2EndDate);
662
                            }
663
                            #endregion
664

    
665
                            if (parameters.Count > 0)
666
                            {
667
                                sbSet.Append(" ,ModifiedUser=@ModifiedUser ");
668
                                parameters.Add("ModifiedUser", userId);
669

    
670
                                parameters.Add("DocID", doc.DocID);
671

    
672
                                query = $@"
673
update dbo.Documents
674
set    ModifiedDate=getdate() {sbSet}
675
where  [DocID]=@DocID;";
676
                                base.Execute(query, parameters, transaction);
677
                            }
678
                        }
679
                    }
680
                    transaction.Commit();
681
                    isSuccess = true;
682
                }
683
            }
684
            catch (Exception ex)
685
            {
686
                throw ex;
687
            }
688

    
689
            return isSuccess;
690
        }
691

    
692

    
693
        //ID2
694
        public IEnumerable<ID2Drawings> GetID2DrawingsByProject(ID2ProjectInfo id2Info)
695
        {
696
            try
697
            {
698
                string query = $@"
699
select @Name PROJECTNAME
700
      ,dw.[UID], dw.[NAME], left(dw.[NAME], len(dw.[NAME]) - dw.lastidx) DOCNAME
701
      ,case when rtrim(ltrim(isnull(convert(varchar, dw.[DATETIME]),''))) = '' then null else convert(datetime, convert(varchar, dw.[DATETIME])) end [DATETIME]
702
      ,dw.OCCUPIED, dw.[Image]
703
from
704
(
705
    select [UID], [NAME], [DATETIME], OCCUPIED, [Image], charindex('.', reverse([NAME])) lastidx
706
    from   dbo.Drawings
707
) dw;";
708
                return Query<ID2Drawings>(query, id2Info);
709
            }
710
            catch (Exception ex)
711
            {
712
                throw ex;
713
            }
714
        }
715
    }
716
}
클립보드 이미지 추가 (최대 크기: 500 MB)