Free cookie consent management tool by TermsFeed Policy Generator

source: branches/3040_VectorBasedGP/HeuristicLab.Services.Hive.DataAccess/3.3/Daos/HiveStatistics/DimJobDao.cs @ 17825

Last change on this file since 17825 was 17825, checked in by pfleck, 4 years ago

#3040 Merged trunk into branch.

File size: 3.1 KB
Line 
1#region License Information
2/* HeuristicLab
3 * Copyright (C) Heuristic and Evolutionary Algorithms Laboratory (HEAL)
4 *
5 * This file is part of HeuristicLab.
6 *
7 * HeuristicLab is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation, either version 3 of the License, or
10 * (at your option) any later version.
11 *
12 * HeuristicLab is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with HeuristicLab. If not, see <http://www.gnu.org/licenses/>.
19 */
20#endregion
21
22using System;
23using System.Data.Linq;
24using System.Linq;
25
26namespace HeuristicLab.Services.Hive.DataAccess.Daos.HiveStatistics {
27  public class DimJobDao : GenericDao<Guid, DimJob> {
28    public DimJobDao(DataContext dataContext) : base(dataContext) { }
29
30    public override DimJob GetById(Guid id) {
31      return GetByIdQuery(DataContext, id);
32    }
33
34    public IQueryable<DimJob> GetByUserId(Guid id) {
35      return Table.Where(x => x.UserId == id);
36    }
37
38    public IQueryable<DimJob> GetNotCompletedJobs() {
39      return Table.Where(x => x.DateCompleted == null);
40    }
41
42    public IQueryable<DimJob> GetCompletedJobs() {
43      return Table.Where(x => x.DateCompleted != null);
44    }
45
46    public void UpdateExistingDimJobs() {
47      DataContext.ExecuteCommand(UpdateExistingDimJobsQuery);
48    }
49
50    #region Compiled queries
51    private static readonly Func<DataContext, Guid, DimJob> GetByIdQuery =
52      CompiledQuery.Compile((DataContext db, Guid id) =>
53        (from dimJob in db.GetTable<DimJob>()
54         where dimJob.JobId == id
55         select dimJob).SingleOrDefault());
56    #endregion
57
58    #region String queries
59    private const string UpdateExistingDimJobsQuery = @"
60UPDATE u
61SET
62  u.JobName = case when x.JobId is null then u.JobName else x.JobName end,
63  u.TotalTasks = x.TotalTasks,
64  u.CompletedTasks = x.CompletedTasks,
65  u.DateCompleted =
66    case when x.totaltasks = x.CompletedTasks
67      then (case when x.JobId is null and x.DateCompleted is null then GETDATE() else x.DateCompleted end)
68    else u.DateCompleted
69  end,
70  u.ProjectId = case when x.JobId is null then u.ProjectId else x.ProjectId end
71FROM [statistics].dimjob u
72JOIN (
73  SELECT
74    dj.JobId as DimJobId,
75    j.JobId as JobId,
76    j.Name as JobName,
77    COUNT(*) as TotalTasks,
78    SUM(
79    CASE
80    WHEN TaskState in ('Finished', 'Aborted', 'Failed') then 1
81    ELSE 0
82    END) as CompletedTasks,
83    MAX(EndTime) as DateCompleted,
84    dp.ProjectId as ProjectId
85  from [statistics].DimJob dj
86  join [statistics].FactTask ft on dj.JobId = ft.JobId
87  left join Job j on j.JobId = dj.JobId
88  left join [statistics].DimProject dp on j.ProjectId = dp.ProjectId
89  where dj.DateCompleted is null and dp.DateExpired is null
90  group by dj.JobId, j.JobId, j.Name, dp.ProjectId
91) as x on u.JobId = x.DimJobId";
92    #endregion
93  }
94}
Note: See TracBrowser for help on using the repository browser.