lixiaojun
2022-08-03 37caf664f302b7fbeef0bb00f5fd6b93810957ad
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
 
namespace IStation.DAL
{
    /// <summary>
    /// 能效汇总(多)年记录
    /// </summary>
    public class EtaSumMultiYearRecord : CorpDAL<Entity.EtaSumMultiYearRecord>
    {
        /// <summary>
        /// 
        /// </summary>
        public override ConnectionConfig ConnectionConfig
        {
            get { return ConfigHelper.RecordConnectionConfig; }
        }
 
        /// <summary>
        /// 
        /// </summary>
        /// <param name="list"></param>
        /// <returns></returns>
        public override bool Inserts(List<Entity.EtaSumMultiYearRecord> list)
        {
            if (list == null || list.Count < 1)
                return default;
            var corpIds = list.Select(x => x.CorpID).Distinct().ToList();
            if (corpIds.Count() != 1 || corpIds[0] < 1)
                return default;
            using (SqlSugarClient db = new SqlSugarClient(ConnectionConfig))
            {
                try
                {
                    db.BeginTran();
                    foreach (var item in list)
                    {
                        var id = db.Insertable(item).ExecuteReturnSnowflakeId();
                        if (id < 1)
                        {
                            db.RollbackTran();
                            return false;
                        }
                    }
                    db.CommitTran();
                    return true;
                }
                catch
                {
                    db.RollbackTran();
                    return false;
                }
 
            }
        }
 
        /// <summary>
        /// 通过对象获取
        /// </summary>
        public List<Entity.EtaSumMultiYearRecord> GetByObject(long CorpID, string ObjectType, long ObjectID)
        {
            using (var db = new SqlSugarClient(ConnectionConfig))
            {
                return db.Queryable<Entity.EtaSumMultiYearRecord>()
                            .Where(x => x.CorpID == CorpID && x.ObjectType == ObjectType && x.ObjectID == ObjectID)
                            .ToList();
            }
        }
 
        /// <summary>
        /// 通过对象获取某年的数据数据
        /// </summary>
        public List<Entity.EtaSumMultiYearRecord> GetByObjectOfYear(long CorpID, string ObjectType, long ObjectID, int Year)
        {
            using (var db = new SqlSugarClient(ConnectionConfig))
            {
                return db.Queryable<Entity.EtaSumMultiYearRecord>()
                            .Where(x => x.CorpID == CorpID && x.ObjectType == ObjectType && x.ObjectID == ObjectID)
                            .Where(x => x.DataYear == Year)
                            .ToList();
            }
        }
 
        /// <summary>
        /// 通过对象获取年区间内的数据
        /// </summary>
        public List<Entity.EtaSumMultiYearRecord> GetByObjectOfYearRange(long CorpID, string ObjectType, long ObjectID, int StartYear, int EndYear) 
        {
            if (StartYear > EndYear)
                return default;
            using (var db = new SqlSugarClient(ConnectionConfig))
            {
                return db.Queryable<Entity.EtaSumMultiYearRecord>()
                            .Where(x => x.CorpID == CorpID && x.ObjectType == ObjectType && x.ObjectID == ObjectID)
                            .Where(x => x.DataYear >= StartYear && x.DataYear <= EndYear)
                            .ToList();
            }
        }
 
    }
}