forked from ddrilling/AsbCloudServer
813 lines
47 KiB
C#
813 lines
47 KiB
C#
using Microsoft.EntityFrameworkCore;
|
||
using System;
|
||
using System.Collections.Generic;
|
||
using System.Linq;
|
||
using System.Threading;
|
||
using System.Threading.Tasks;
|
||
using System.Data.Common;
|
||
|
||
#nullable disable
|
||
|
||
namespace AsbCloudDb.Model
|
||
{
|
||
//Scaffold-DbContext "Host=localhost;Database=postgres;Username=postgres;Password=q;Persist Security Info=True" Npgsql.EntityFrameworkCore.PostgreSQL -OutputDir Model -DataAnnotations
|
||
public partial class AsbCloudDbContext : DbContext, IAsbCloudDbContext
|
||
{
|
||
public virtual DbSet<Cluster> Clusters { get; set; }
|
||
public virtual DbSet<Company> Companies { get; set; }
|
||
public virtual DbSet<DataSaubBase> DataSaubBases { get; set; }
|
||
public virtual DbSet<Deposit> Deposits { get; set; }
|
||
public virtual DbSet<User> Users { get; set; }
|
||
public virtual DbSet<UserRole> UserRoles { get; set; }
|
||
public virtual DbSet<Well> Wells { get; set; }
|
||
public virtual DbSet<ReportProperty> ReportProperties { get; set; }
|
||
public virtual DbSet<FileInfo> Files { get; set; }
|
||
public virtual DbSet<FileCategory> FileCategories { get; set; }
|
||
public virtual DbSet<Telemetry> Telemetries { get; set; }
|
||
public virtual DbSet<TelemetryEvent> TelemetryEvents { get; set; }
|
||
public virtual DbSet<TelemetryMessage> TelemetryMessages { get; set; }
|
||
public virtual DbSet<TelemetryUser> TelemetryUsers { get; set; }
|
||
public virtual DbSet<WellOperationCategory> TelemetryOperations { get; set; }
|
||
public virtual DbSet<TelemetryAnalysis> TelemetryAnalysis { get; set; }
|
||
public virtual DbSet<WellSection> WellSections { get; set; }
|
||
public virtual DbSet<WellSectionType> WellSectionTypes { get; set; }
|
||
public virtual DbSet<WellOperation> WellOperations { get; set; }
|
||
public virtual DbSet<WellType> WellTypes { get; set; }
|
||
public virtual DbSet<LastData> LastData { get; set; }
|
||
|
||
//var options = new DbContextOptionsBuilder<AsbCloudDbContext>()
|
||
// .UseNpgsql("Host=localhost;Database=postgres;Username=postgres;Password=q;Persist Security Info=True")
|
||
// .Options;
|
||
//var context = new AsbCloudDbContext(options);
|
||
|
||
public AsbCloudDbContext(DbContextOptions<AsbCloudDbContext> options)
|
||
: base(options)
|
||
{
|
||
Database.EnsureCreated();
|
||
}
|
||
|
||
//protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
|
||
//{
|
||
// if (!optionsBuilder.IsConfigured)
|
||
// {
|
||
// optionsBuilder.UseNpgsql(connectionString);
|
||
// }
|
||
//}
|
||
|
||
protected override void OnModelCreating(ModelBuilder modelBuilder)
|
||
{
|
||
modelBuilder.HasPostgresExtension("adminpack")
|
||
.HasAnnotation("Relational:Collation", "Russian_Russia.1251");
|
||
|
||
modelBuilder.Entity<Cluster>(entity =>
|
||
{
|
||
entity.HasOne(d => d.Deposit)
|
||
.WithMany(p => p.Clusters)
|
||
.HasForeignKey(d => d.IdDeposit)
|
||
.HasConstraintName("t_cluster_t_deposit_id_fk");
|
||
});
|
||
|
||
modelBuilder.Entity<DataSaubBase>(entity =>
|
||
{
|
||
entity.HasOne(d => d.Telemetry)
|
||
.WithMany(p => p.DataSaubBases)
|
||
.HasForeignKey(d => d.IdTelemetry)
|
||
.OnDelete(DeleteBehavior.ClientSetNull)
|
||
.HasConstraintName("t_data_saub_base_t_telemetry_id_fk");
|
||
});
|
||
|
||
modelBuilder.Entity<TelemetryMessage>(entity =>
|
||
{
|
||
entity.HasOne(d => d.Telemetry)
|
||
.WithMany(p => p.Messages)
|
||
.HasForeignKey(d => d.IdTelemetry)
|
||
.HasConstraintName("t_messages_t_telemetry_id_fk");
|
||
});
|
||
|
||
modelBuilder.Entity<TelemetryUser>(entity =>
|
||
{
|
||
entity.HasKey(nameof(TelemetryUser.IdTelemetry), nameof(TelemetryUser.IdUser));
|
||
entity.HasOne(d => d.Telemetry)
|
||
.WithMany(p => p.Users)
|
||
.HasForeignKey(d => d.IdTelemetry)
|
||
.OnDelete(DeleteBehavior.ClientSetNull)
|
||
.HasConstraintName("t_telemetry_user_t_telemetry_id_fk");
|
||
});
|
||
|
||
modelBuilder.Entity<TelemetryAnalysis>(entity =>
|
||
{
|
||
entity.HasOne(d => d.Telemetry)
|
||
.WithMany(p => p.Analysis)
|
||
.HasForeignKey(d => d.IdTelemetry)
|
||
.HasConstraintName("t_analysis_t_telemetry_id_fk");
|
||
|
||
entity.HasOne(d => d.Operation)
|
||
.WithMany(p => p.Analysis)
|
||
.HasForeignKey(d => d.IdOperation)
|
||
.OnDelete(DeleteBehavior.SetNull)
|
||
.HasConstraintName("t_analysis_t_operation_id_fk");
|
||
});
|
||
|
||
modelBuilder.Entity<TelemetryEvent>(entity =>
|
||
{
|
||
entity.HasKey(nameof(TelemetryEvent.IdTelemetry), nameof(TelemetryEvent.IdEvent));
|
||
entity.HasOne(d => d.Telemetry)
|
||
.WithMany(p => p.Events)
|
||
.HasForeignKey(d => d.IdTelemetry)
|
||
.HasConstraintName("t_event_t_telemetry_id_fk");
|
||
});
|
||
|
||
modelBuilder.Entity<User>(entity =>
|
||
{
|
||
entity.HasOne(d => d.Company)
|
||
.WithMany(p => p.Users)
|
||
.HasForeignKey(d => d.IdCompany)
|
||
.HasConstraintName("t_user_t_company_id_fk");
|
||
|
||
entity.HasIndex(d => d.Login)
|
||
.IsUnique();
|
||
});
|
||
|
||
modelBuilder.Entity<Well>(entity =>
|
||
{
|
||
entity.HasOne(d => d.Cluster)
|
||
.WithMany(p => p.Wells)
|
||
.HasForeignKey(d => d.IdCluster)
|
||
.HasConstraintName("t_well_t_cluster_id_fk");
|
||
|
||
entity.HasOne(d => d.Telemetry)
|
||
.WithOne(p => p.Well)
|
||
.HasForeignKey<Well>(d => d.IdTelemetry)
|
||
.HasConstraintName("t_well_t_telemetry_id_fk");
|
||
});
|
||
|
||
modelBuilder.Entity<WellSection>(entity =>
|
||
{
|
||
entity.HasIndex(e => e.WellDepthPlan)
|
||
.HasDatabaseName("IX_t_well_section_well_depth_plan");
|
||
});
|
||
|
||
modelBuilder.Entity<RelationCompanyWell>(entity =>
|
||
{
|
||
|
||
entity.HasKey(nameof(RelationCompanyWell.IdCompany), nameof(RelationCompanyWell.IdWell));
|
||
|
||
entity.HasOne(r => r.Well)
|
||
.WithMany(w => w.RelationCompaniesWells)
|
||
.HasForeignKey(r => r.IdWell)
|
||
.HasConstraintName("t_relation_company_well_t_well_id_fk");
|
||
|
||
entity.HasOne(r => r.Company)
|
||
.WithMany(w => w.RelationCompaniesWells)
|
||
.HasForeignKey(r => r.IdCompany)
|
||
.HasConstraintName("t_relation_company_well_t_company_id_fk");
|
||
});
|
||
|
||
modelBuilder.Entity<WellOperation>(entity =>
|
||
{
|
||
entity.HasIndex(d => d.WellDepth);
|
||
entity.HasIndex(d => d.StartDate);
|
||
});
|
||
|
||
FillData(modelBuilder);
|
||
FillDemoData(modelBuilder);
|
||
}
|
||
|
||
private static void FillData(ModelBuilder modelBuilder)
|
||
{
|
||
modelBuilder.Entity<UserRole>(entity =>
|
||
{
|
||
entity.HasData(new List<UserRole>{
|
||
new UserRole{ Id = 1, Caption = "Администратор", },
|
||
});
|
||
});
|
||
|
||
modelBuilder.Entity<User>(entity =>
|
||
{
|
||
entity.HasData(new List<User>{
|
||
new User{
|
||
Id = 1,
|
||
IdCompany = 1,
|
||
IdRole = 1,
|
||
Level = int.MaxValue,
|
||
Login = "dev",
|
||
PasswordHash = "Vlcj|4fa529103dde7ff72cfe76185f344d4aa87931f8e1b2044e8a7739947c3d18923464eaad93843e4f809c5e126d013072", // dev
|
||
Name = "Разработчик",
|
||
},
|
||
});
|
||
});
|
||
|
||
modelBuilder.Entity<Company>(entity =>
|
||
{
|
||
entity.HasData(new List<Company>{
|
||
new Company{ Id = 1, Caption = "ООО \"АСБ\"", IdCompanyType = 3},
|
||
});
|
||
});
|
||
|
||
modelBuilder.Entity<WellOperationCategory>(entity =>
|
||
{
|
||
entity.HasData(new List<WellOperationCategory> {
|
||
// Автоматически опеределяемые операции
|
||
new WellOperationCategory {Id = 1, Name = "Невозможно определить операцию", Code = 0},
|
||
new WellOperationCategory {Id = 2, Name = "Роторное бурение", Code = 0 },
|
||
new WellOperationCategory {Id = 3, Name = "Слайдирование", Code = 0 },
|
||
new WellOperationCategory {Id = 4, Name = "Подъем с проработкой", Code = 0 },
|
||
new WellOperationCategory {Id = 5, Name = "Спуск с проработкой", Code = 0 },
|
||
new WellOperationCategory {Id = 6, Name = "Подъем с промывкой", Code = 0 },
|
||
new WellOperationCategory {Id = 7, Name = "Спуск с промывкой", Code = 0 },
|
||
new WellOperationCategory {Id = 8, Name = "Спуск в скважину", Code = 0 },
|
||
new WellOperationCategory {Id = 9, Name = "Спуск с вращением", Code = 0 },
|
||
new WellOperationCategory {Id = 10, Name = "Подъем из скважины", Code = 0 },
|
||
new WellOperationCategory {Id = 11, Name = "Подъем с вращением", Code = 0 },
|
||
new WellOperationCategory {Id = 12, Name = "Промывка в покое", Code = 0 },
|
||
new WellOperationCategory {Id = 13, Name = "Промывка с вращением", Code = 0 },
|
||
new WellOperationCategory {Id = 14, Name = "Удержание в клиньях", Code = 0 },
|
||
new WellOperationCategory {Id = 15, Name = "Неподвижное состояние", Code = 0 },
|
||
new WellOperationCategory {Id = 16, Name = "Вращение без циркуляции", Code = 0 },
|
||
new WellOperationCategory {Id = 17, Name = "На поверхности", Code = 0 },
|
||
// Операции ручного ввода
|
||
new WellOperationCategory {Id = 1001, Name = "Бурение в интервале", Code = 0 },
|
||
new WellOperationCategory {Id = 1002, Name = "ГИС", Code = 0 },
|
||
new WellOperationCategory {Id = 1003, Name = "ГФР", Code = 0 },
|
||
new WellOperationCategory {Id = 1004, Name = "Монтаж ПВО", Code = 0 },
|
||
new WellOperationCategory {Id = 1005, Name = "Демонтаж ПВО", Code = 0 },
|
||
new WellOperationCategory {Id = 1006, Name = "Установка ФА", Code = 0 },
|
||
new WellOperationCategory {Id = 1007, Name = "Оборудование устья", Code = 0 },
|
||
new WellOperationCategory {Id = 1008, Name = "ОЗЦ", Code = 0 },
|
||
new WellOperationCategory {Id = 1009, Name = "Оборудование устья", Code = 0 },
|
||
new WellOperationCategory {Id = 1010, Name = "ОЗЦ", Code = 0 },
|
||
new WellOperationCategory {Id = 1011, Name = "Начало цикла строительства скважины", Code = 0 },
|
||
new WellOperationCategory {Id = 1012, Name = "Окончание цикла строительства скважины", Code = 0 },
|
||
new WellOperationCategory {Id = 1013, Name = "Опрессовка ПВО", Code = 0 },
|
||
new WellOperationCategory {Id = 1014, Name = "Опресовка Ц.К.", Code = 0 },
|
||
new WellOperationCategory {Id = 1015, Name = "Опрессовка ВЗД", Code = 0 },
|
||
new WellOperationCategory {Id = 1016, Name = "Перевод скв на другой тип промывочной жидкости", Code = 0 },
|
||
new WellOperationCategory {Id = 1017, Name = "Перезапись каротажа", Code = 0 },
|
||
new WellOperationCategory {Id = 1018, Name = "Перетяжка талевого каната", Code = 0 },
|
||
new WellOperationCategory {Id = 1019, Name = "Перетяжка тальканата", Code = 0 },
|
||
new WellOperationCategory {Id = 1020, Name = "Подъем инструмента", Code = 0 },
|
||
new WellOperationCategory {Id = 1021, Name = "Подъем инструмента с промывкой", Code = 0 },
|
||
new WellOperationCategory {Id = 1022, Name = "Обратная проработка", Code = 0 },
|
||
new WellOperationCategory {Id = 1023, Name = "Сборка инструмента", Code = 0 },
|
||
new WellOperationCategory {Id = 1024, Name = "Подготовительные работы", Code = 0 },
|
||
new WellOperationCategory {Id = 1025, Name = "Сборка КНБК", Code = 0 },
|
||
new WellOperationCategory {Id = 1026, Name = "Разборка КНБК", Code = 0 },
|
||
new WellOperationCategory {Id = 1027, Name = "Промывка", Code = 0 },
|
||
new WellOperationCategory {Id = 1028, Name = "Промежуточная промывка", Code = 0 },
|
||
new WellOperationCategory {Id = 1029, Name = "Прокачка пачек", Code = 0 },
|
||
new WellOperationCategory {Id = 1030, Name = "Разбуривание тех.оснастки", Code = 0 },
|
||
new WellOperationCategory {Id = 1031, Name = "Ремонт", Code = 0 },
|
||
new WellOperationCategory {Id = 1032, Name = "Спуск инструмента", Code = 0 },
|
||
new WellOperationCategory {Id = 1033, Name = "Спуск инструмента с промывкой", Code = 0 },
|
||
new WellOperationCategory {Id = 1034, Name = "Прямая проработка", Code = 0 },
|
||
new WellOperationCategory {Id = 1035, Name = "Принудительная проработка", Code = 0 },
|
||
new WellOperationCategory {Id = 1036, Name = "Спуск обсадной колонны", Code = 0 },
|
||
new WellOperationCategory {Id = 1037, Name = "Тех СПО-подъем", Code = 0 },
|
||
new WellOperationCategory {Id = 1038, Name = "Тех СПО-спуск", Code = 0 },
|
||
new WellOperationCategory {Id = 1039, Name = "Техническое обслуживание", Code = 0 },
|
||
new WellOperationCategory {Id = 1040, Name = "Цементаж", Code = 0 },
|
||
new WellOperationCategory {Id = 1041, Name = "Шаблонировка ствола", Code = 0 },
|
||
new WellOperationCategory {Id = 1042, Name = "Геологическое осложнение", Code = 0 },
|
||
new WellOperationCategory {Id = 1043, Name = "НПВ", Code = 0 },
|
||
new WellOperationCategory {Id = 1044, Name = "ВМР", Code = 0 },
|
||
new WellOperationCategory {Id = 1045, Name = "Прочее", Code = 0 },
|
||
new WellOperationCategory {Id = 1046, Name = "Спуск КНБК", Code = 0 },
|
||
new WellOperationCategory {Id = 1047, Name = "Подъем КНБК", Code = 0 },
|
||
new WellOperationCategory {Id = 1048, Name = "Спуск ОК", Code = 0 }
|
||
});
|
||
});
|
||
|
||
modelBuilder.Entity<FileCategory>(entity =>
|
||
{
|
||
entity.HasData(new List<FileCategory> {
|
||
new FileCategory {Id = 1, Name = "Растворный сервис", ShortName = "fluidService"},
|
||
new FileCategory {Id = 2, Name = "Цементирование", ShortName = "cement"},
|
||
new FileCategory {Id = 3, Name = "ННБ", ShortName = "nnb"},
|
||
new FileCategory {Id = 4, Name = "ГТИ", ShortName = "gti"},
|
||
new FileCategory {Id = 5, Name = "Документы по скважине", ShortName = "wellDocuments"},
|
||
new FileCategory {Id = 6, Name = "Супервайзер", ShortName = "supervisor"},
|
||
new FileCategory {Id = 7, Name = "Мастер", ShortName = "master"},
|
||
new FileCategory {Id = 8, Name = "Последний замер бурового раствора ПЛАН", ShortName = "fluidPlanLastData"},
|
||
new FileCategory {Id = 9, Name = "Последний замер бурового раствора ФАКТ", ShortName = "fluidFactLastData"},
|
||
new FileCategory {Id = 10, Name = "Последние данные Шламограммы", ShortName = "mudLastData"},
|
||
new FileCategory {Id = 11, Name = "Последние данные ННБ", ShortName = "nnbLastData"},
|
||
new FileCategory {Id = 12, Name = "Рапорт", ShortName = "report"}
|
||
});
|
||
});
|
||
|
||
modelBuilder.Entity<WellSectionType>(entity => {
|
||
entity.HasData(new List<WellSectionType>{
|
||
new WellSectionType{ Id = 1, Caption = "Пилотный ствол"},
|
||
new WellSectionType{ Id = 2, Caption = "Направление"},
|
||
new WellSectionType{ Id = 3, Caption = "Кондуктор"},
|
||
new WellSectionType{ Id = 4, Caption = "Эксплуатационная колонна"},
|
||
new WellSectionType{ Id = 5, Caption = "Транспортный ствол"},
|
||
new WellSectionType{ Id = 6, Caption = "Хвостовик"},
|
||
});
|
||
});
|
||
}
|
||
|
||
private static void FillDemoData(ModelBuilder modelBuilder)
|
||
{
|
||
modelBuilder.Entity<CompanyType>(entity =>
|
||
{
|
||
entity.HasData(new List<CompanyType>{
|
||
new CompanyType{ Id = 1, Caption = "Недрапользователь", },
|
||
new CompanyType{ Id = 2, Caption = "Буровой подрядчик", },
|
||
new CompanyType{ Id = 3, Caption = "Сервис автоматизации бурения", },
|
||
});
|
||
});
|
||
|
||
modelBuilder.Entity<Deposit>(entity =>
|
||
{
|
||
entity.HasData(new List<Deposit> {
|
||
new Deposit{Id = 1, Caption = "м/р 1", Latitude = 60.8705722222222, Longitude = 70.3811888888889 },
|
||
});
|
||
});
|
||
|
||
modelBuilder.Entity<Cluster>(entity =>
|
||
{
|
||
entity.HasData(new List<Cluster> {
|
||
new Cluster{Id = 1, Caption = "к39.1", IdDeposit = 1, Latitude = 60.8705722222222, Longitude = 70.3811888888889},
|
||
new Cluster{Id = 2, Caption = "к151", IdDeposit = 1, Latitude = 60.8205750000000, Longitude = 70.1343833333334},
|
||
new Cluster{Id = 3, Caption = "к611", IdDeposit = 1, Latitude = 60.8100666666667, Longitude = 69.7778388888889},
|
||
new Cluster{Id = 4, Caption = "к203", IdDeposit = 1, Latitude = 60.8928805555556, Longitude = 70.3272055555556},
|
||
new Cluster{Id = 5, Caption = "к221", IdDeposit = 1, Latitude = 60.6672055555556, Longitude = 69.6603861111111},
|
||
});
|
||
});
|
||
|
||
modelBuilder.Entity<Telemetry>(entity =>
|
||
{
|
||
entity.HasData(new List<Telemetry>{
|
||
new Telemetry{
|
||
Id = 1,
|
||
RemoteUid = "123",
|
||
Info = new TelemetryInfo
|
||
{
|
||
Well = "1",
|
||
Cluster = "1",
|
||
Comment = "",
|
||
Deposit = "1",
|
||
Customer = "1",
|
||
HmiVersion = "1",
|
||
PlcVersion = "1",
|
||
TimeZoneId = "1",
|
||
DrillingStartDate = DateTime.Parse("2021-06-29T12:01:19.000000"),
|
||
TimeZoneOffsetTotalHours = 5.0
|
||
},
|
||
}
|
||
});
|
||
});
|
||
|
||
modelBuilder.Entity<Well>(entity =>
|
||
{
|
||
entity.HasData(new List<Well> {
|
||
new Well{Id = 1, IdCluster = 1, IdTelemetry = 1, Caption = "скв 16314", Latitude = 60.8705722222222, Longitude = 70.3811888888889},
|
||
new Well{Id = 2, IdCluster = 1, Caption = "скв 16311", Latitude = 60.8705722222222, Longitude = 70.3811888888889},
|
||
new Well{Id = 3, IdCluster = 2, Caption = "скв 16315", Latitude = 60.8205750000000, Longitude = 70.1343833333334},
|
||
new Well{Id = 4, IdCluster = 2, Caption = "скв 16318", Latitude = 60.8205750000000, Longitude = 70.1343833333334},
|
||
new Well{Id = 5, IdCluster = 3, Caption = "скв 16310", Latitude = 60.8100666666667, Longitude = 69.7778388888889},
|
||
new Well{Id = 6, IdCluster = 4, Caption = "скв 16316", Latitude = 60.8928805555556, Longitude = 70.3272055555556},
|
||
new Well{Id = 7, IdCluster = 5, Caption = "скв 16312", Latitude = 60.6672055555556, Longitude = 69.6603861111111},
|
||
new Well{Id = 8, IdCluster = 5, Caption = "скв 16313", Latitude = 60.6672055555556, Longitude = 69.6603861111111},
|
||
new Well{Id = 9, IdCluster = 5, Caption = "скв 42669", Latitude = 60.6672055555556, Longitude = 69.6603861111111},
|
||
});
|
||
});
|
||
|
||
modelBuilder.Entity<RelationCompanyWell>(entity =>
|
||
{
|
||
entity.HasData(new List<RelationCompanyWell> {
|
||
new RelationCompanyWell{ IdWell = 1, IdCompany = 1},
|
||
new RelationCompanyWell{ IdWell = 2, IdCompany = 1},
|
||
new RelationCompanyWell{ IdWell = 3, IdCompany = 1},
|
||
new RelationCompanyWell{ IdWell = 4, IdCompany = 1},
|
||
new RelationCompanyWell{ IdWell = 5, IdCompany = 1},
|
||
new RelationCompanyWell{ IdWell = 6, IdCompany = 1},
|
||
new RelationCompanyWell{ IdWell = 7, IdCompany = 1},
|
||
new RelationCompanyWell{ IdWell = 8, IdCompany = 1},
|
||
new RelationCompanyWell{ IdWell = 9, IdCompany = 1},
|
||
});
|
||
});
|
||
|
||
modelBuilder.Entity<WellOperation>(entity =>
|
||
{
|
||
entity.HasData(new List<WellOperation> {
|
||
new WellOperation{ Id = 1, IdWell = 1, IdWellSectionType = 1,
|
||
IdCategory = 1001, IdType = 0,
|
||
WellDepth = 200, StartDate = DateTime.Now.AddHours(1),
|
||
DurationHours = 1.2},
|
||
new WellOperation{ Id = 2, IdWell = 1, IdWellSectionType = 1,
|
||
IdCategory = 1001, IdType = 0,
|
||
WellDepth = 300, StartDate = DateTime.Now.AddHours(2.5),
|
||
DurationHours = 1.5},
|
||
new WellOperation{ Id = 3, IdWell = 1, IdWellSectionType = 1,
|
||
IdCategory = 1001, IdType = 1,
|
||
WellDepth = 210, StartDate = DateTime.Now.AddHours(1.5),
|
||
DurationHours = 1},
|
||
new WellOperation{ Id = 4, IdWell = 1, IdWellSectionType = 1,
|
||
IdCategory = 1001, IdType = 1,
|
||
WellDepth = 310, StartDate = DateTime.Now.AddHours(2),
|
||
DurationHours = 1.5},
|
||
new WellOperation{ Id = 5, IdWell = 1, IdWellSectionType = 2,
|
||
IdCategory = 1001, IdType = 0,
|
||
WellDepth = 200, StartDate = DateTime.Now.AddHours(1),
|
||
DurationHours = 1.2},
|
||
new WellOperation{ Id = 6, IdWell = 1, IdWellSectionType = 2,
|
||
IdCategory = 1001, IdType = 0,
|
||
WellDepth = 300, StartDate = DateTime.Now.AddHours(2.5),
|
||
DurationHours = 1.5},
|
||
new WellOperation{ Id = 7, IdWell = 1, IdWellSectionType = 2,
|
||
IdCategory = 1001, IdType = 1,
|
||
WellDepth = 210, StartDate = DateTime.Now.AddHours(1.5),
|
||
DurationHours = 1},
|
||
new WellOperation{ Id = 8, IdWell = 1, IdWellSectionType = 2,
|
||
IdCategory = 1001, IdType = 1,
|
||
WellDepth = 310, StartDate = DateTime.Now.AddHours(2),
|
||
DurationHours = 1.5},
|
||
new WellOperation{ Id = 9, IdWell = 1, IdWellSectionType = 3,
|
||
IdCategory = 1001, IdType = 0,
|
||
WellDepth = 500, StartDate = DateTime.Now.AddHours(1),
|
||
DurationHours = 1.2},
|
||
new WellOperation{ Id = 10, IdWell = 1, IdWellSectionType = 3,
|
||
IdCategory = 1001, IdType = 0,
|
||
WellDepth = 510, StartDate = DateTime.Now.AddHours(2),
|
||
DurationHours = 1.2},
|
||
new WellOperation{ Id = 11, IdWell = 1, IdWellSectionType = 3,
|
||
IdCategory = 1001, IdType = 1,
|
||
WellDepth = 510, StartDate = DateTime.Now.AddHours(1.5),
|
||
DurationHours = 1},
|
||
new WellOperation{ Id = 12, IdWell = 1, IdWellSectionType = 3,
|
||
IdCategory = 1001, IdType = 1,
|
||
WellDepth = 520, StartDate = DateTime.Now.AddHours(2),
|
||
DurationHours = 1.5},
|
||
|
||
|
||
new WellOperation{ Id = 13, IdWell = 1, IdWellSectionType = 1,
|
||
IdCategory = 1046, IdType = 0,
|
||
WellDepth = 200, StartDate = DateTime.Now.AddHours(2.5),
|
||
DurationHours = 15.5},
|
||
new WellOperation{ Id = 14, IdWell = 1, IdWellSectionType = 1,
|
||
IdCategory = 1046, IdType = 0,
|
||
WellDepth = 210, StartDate = DateTime.Now.AddHours(3),
|
||
DurationHours = 17.2},
|
||
new WellOperation{ Id = 15, IdWell = 1, IdWellSectionType = 1,
|
||
IdCategory = 1046, IdType = 1,
|
||
WellDepth = 220, StartDate = DateTime.Now.AddHours(2.7),
|
||
DurationHours = 15.2},
|
||
new WellOperation{ Id = 16, IdWell = 1, IdWellSectionType = 1,
|
||
IdCategory = 1046, IdType = 1,
|
||
WellDepth = 230, StartDate = DateTime.Now.AddHours(3.1),
|
||
DurationHours = 17.8},
|
||
new WellOperation{ Id = 17, IdWell = 1, IdWellSectionType = 2,
|
||
IdCategory = 1046, IdType = 0,
|
||
WellDepth = 200, StartDate = DateTime.Now.AddHours(2.5),
|
||
DurationHours = 15.5},
|
||
new WellOperation{ Id = 18, IdWell = 1, IdWellSectionType = 2,
|
||
IdCategory = 1046, IdType = 0,
|
||
WellDepth = 210, StartDate = DateTime.Now.AddHours(3),
|
||
DurationHours = 17.2},
|
||
new WellOperation{ Id = 19, IdWell = 1, IdWellSectionType = 2,
|
||
IdCategory = 1046, IdType = 1,
|
||
WellDepth = 220, StartDate = DateTime.Now.AddHours(2.7),
|
||
DurationHours = 15.2},
|
||
new WellOperation{ Id = 20, IdWell = 1, IdWellSectionType = 2,
|
||
IdCategory = 1046, IdType = 1,
|
||
WellDepth = 230, StartDate = DateTime.Now.AddHours(3.1),
|
||
DurationHours = 17.8},
|
||
new WellOperation{ Id = 21, IdWell = 1, IdWellSectionType = 3,
|
||
IdCategory = 1046, IdType = 0,
|
||
WellDepth = 700, StartDate = DateTime.Now.AddHours(2.5),
|
||
DurationHours = 16.2},
|
||
new WellOperation{ Id = 22, IdWell = 1, IdWellSectionType = 3,
|
||
IdCategory = 1046, IdType = 0,
|
||
WellDepth = 720, StartDate = DateTime.Now.AddHours(3.5),
|
||
DurationHours = 17.2},
|
||
new WellOperation{ Id = 23, IdWell = 1, IdWellSectionType = 3,
|
||
IdCategory = 1046, IdType = 1,
|
||
WellDepth = 715, StartDate = DateTime.Now.AddHours(2.7),
|
||
DurationHours = 15.2},
|
||
new WellOperation{ Id = 24, IdWell = 1, IdWellSectionType = 3,
|
||
IdCategory = 1046, IdType = 1,
|
||
WellDepth = 720, StartDate = DateTime.Now.AddHours(3),
|
||
DurationHours = 18.2},
|
||
|
||
|
||
|
||
new WellOperation{ Id = 25, IdWell = 1, IdWellSectionType = 1,
|
||
IdCategory = 1047, IdType = 0,
|
||
WellDepth = 600, StartDate = DateTime.Now.AddHours(4),
|
||
DurationHours = 5},
|
||
new WellOperation{ Id = 26, IdWell = 1, IdWellSectionType = 1,
|
||
IdCategory = 1047, IdType = 0,
|
||
WellDepth = 650, StartDate = DateTime.Now.AddHours(4.5),
|
||
DurationHours = 5.5},
|
||
new WellOperation{ Id = 27, IdWell = 1, IdWellSectionType = 1,
|
||
IdCategory = 1047, IdType = 1,
|
||
WellDepth = 700, StartDate = DateTime.Now.AddHours(5.5),
|
||
DurationHours = 8},
|
||
new WellOperation{ Id = 28, IdWell = 1, IdWellSectionType = 1,
|
||
IdCategory = 1047, IdType = 1,
|
||
WellDepth = 710, StartDate = DateTime.Now.AddHours(5.7),
|
||
DurationHours = 7.2},
|
||
new WellOperation{ Id = 29, IdWell = 1, IdWellSectionType = 2,
|
||
IdCategory = 1047, IdType = 0,
|
||
WellDepth = 600, StartDate = DateTime.Now.AddHours(4),
|
||
DurationHours = 5},
|
||
new WellOperation{ Id = 30, IdWell = 1, IdWellSectionType = 2,
|
||
IdCategory = 1047, IdType = 0,
|
||
WellDepth = 650, StartDate = DateTime.Now.AddHours(4.5),
|
||
DurationHours = 5.5},
|
||
new WellOperation{ Id = 31, IdWell = 1, IdWellSectionType = 2,
|
||
IdCategory = 1047, IdType = 1,
|
||
WellDepth = 700, StartDate = DateTime.Now.AddHours(5.5),
|
||
DurationHours = 8},
|
||
new WellOperation{ Id = 32, IdWell = 1, IdWellSectionType = 2,
|
||
IdCategory = 1047, IdType = 1,
|
||
WellDepth = 710, StartDate = DateTime.Now.AddHours(5.7),
|
||
DurationHours = 7.2},
|
||
new WellOperation{ Id = 33, IdWell = 1, IdWellSectionType = 3,
|
||
IdCategory = 1047, IdType = 0,
|
||
WellDepth = 1000, StartDate = DateTime.Now.AddHours(5.25),
|
||
DurationHours = 2.1},
|
||
new WellOperation{ Id = 34, IdWell = 1, IdWellSectionType = 3,
|
||
IdCategory = 1047, IdType = 0,
|
||
WellDepth = 1100, StartDate = DateTime.Now.AddHours(7.5),
|
||
DurationHours = 2},
|
||
new WellOperation{ Id = 35, IdWell = 1, IdWellSectionType = 3,
|
||
IdCategory = 1047, IdType = 1,
|
||
WellDepth = 1000, StartDate = DateTime.Now.AddHours(5.15),
|
||
DurationHours = 2.75},
|
||
new WellOperation{ Id = 36, IdWell = 1, IdWellSectionType = 3,
|
||
IdCategory = 1047, IdType = 1,
|
||
WellDepth = 1250, StartDate = DateTime.Now.AddHours(6.5),
|
||
DurationHours = 3.5},
|
||
|
||
|
||
|
||
|
||
new WellOperation{ Id = 37, IdWell = 1, IdWellSectionType = 1,
|
||
IdCategory = 1048, IdType = 0,
|
||
WellDepth = 600, StartDate = DateTime.Now.AddHours(4),
|
||
DurationHours = 5},
|
||
new WellOperation{ Id = 38, IdWell = 1, IdWellSectionType = 1,
|
||
IdCategory = 1048, IdType = 0,
|
||
WellDepth = 650, StartDate = DateTime.Now.AddHours(4.2),
|
||
DurationHours = 5.5},
|
||
new WellOperation{ Id = 39, IdWell = 1, IdWellSectionType = 1,
|
||
IdCategory = 1048, IdType = 1,
|
||
WellDepth = 700, StartDate = DateTime.Now.AddHours(5.5),
|
||
DurationHours = 7},
|
||
new WellOperation{ Id = 40, IdWell = 1, IdWellSectionType = 1,
|
||
IdCategory = 1048, IdType = 1,
|
||
WellDepth = 710, StartDate = DateTime.Now.AddHours(5.7),
|
||
DurationHours = 7.5},
|
||
new WellOperation{ Id = 41, IdWell = 1, IdWellSectionType = 2,
|
||
IdCategory = 1048, IdType = 0,
|
||
WellDepth = 600, StartDate = DateTime.Now.AddHours(4),
|
||
DurationHours = 5},
|
||
new WellOperation{ Id = 42, IdWell = 1, IdWellSectionType = 2,
|
||
IdCategory = 1048, IdType = 0,
|
||
WellDepth = 650, StartDate = DateTime.Now.AddHours(4.2),
|
||
DurationHours = 5.5},
|
||
new WellOperation{ Id = 43, IdWell = 1, IdWellSectionType = 2,
|
||
IdCategory = 1048, IdType = 1,
|
||
WellDepth = 700, StartDate = DateTime.Now.AddHours(5.5),
|
||
DurationHours = 7},
|
||
new WellOperation{ Id = 44, IdWell = 1, IdWellSectionType = 2,
|
||
IdCategory = 1048, IdType = 1,
|
||
WellDepth = 710, StartDate = DateTime.Now.AddHours(5.7),
|
||
DurationHours = 7.5},
|
||
new WellOperation{ Id = 48, IdWell = 1, IdWellSectionType = 2,
|
||
IdCategory = 1048, IdType = 0,
|
||
WellDepth = 910, StartDate = DateTime.Now.AddHours(5),
|
||
DurationHours = 12},
|
||
new WellOperation{ Id = 49, IdWell = 1, IdWellSectionType = 3,
|
||
IdCategory = 1048, IdType = 0,
|
||
WellDepth = 910, StartDate = DateTime.Now.AddHours(5),
|
||
DurationHours = 2},
|
||
new WellOperation{ Id = 50, IdWell = 1, IdWellSectionType = 3,
|
||
IdCategory = 1048, IdType = 0,
|
||
WellDepth = 950, StartDate = DateTime.Now.AddHours(7.5),
|
||
DurationHours = 2},
|
||
new WellOperation{ Id = 51, IdWell = 1, IdWellSectionType = 3,
|
||
IdCategory = 1048, IdType = 1,
|
||
WellDepth = 980, StartDate = DateTime.Now.AddHours(5),
|
||
DurationHours = 2.5},
|
||
new WellOperation{ Id = 52, IdWell = 1, IdWellSectionType = 3,
|
||
IdCategory = 1048, IdType = 1,
|
||
WellDepth = 1010, StartDate = DateTime.Now.AddHours(6.5),
|
||
DurationHours = 2.5},
|
||
|
||
});
|
||
});
|
||
|
||
modelBuilder.Entity<TelemetryAnalysis>(entity =>
|
||
{
|
||
entity.HasData(new List<TelemetryAnalysis>{
|
||
new TelemetryAnalysis
|
||
{
|
||
Id = 1,
|
||
IdTelemetry = 1,
|
||
IdOperation = 17,
|
||
UnixDate = 1626870355,
|
||
DurationSec = 10,
|
||
OperationStartDepth = null,
|
||
OperationEndDepth = 206,
|
||
IsWellDepthIncreasing = false,
|
||
IsWellDepthDecreasing = false,
|
||
IsBitPositionIncreasing = false,
|
||
IsBitPositionDecreasing = false,
|
||
IsBitPositionLt20 = true,
|
||
IsBlockPositionIncreasing = false,
|
||
IsBlockPositionDecreasing = false,
|
||
IsRotorSpeedLt3 = true,
|
||
IsRotorSpeedGt3 = false,
|
||
IsPressureLt20 = true,
|
||
IsPressureGt20 = false,
|
||
IsHookWeightNotChanges = true,
|
||
IsHookWeightLt3 = true
|
||
},
|
||
new TelemetryAnalysis
|
||
{
|
||
Id = 2,
|
||
IdTelemetry = 1,
|
||
IdOperation = 8,
|
||
UnixDate = 1626870364,
|
||
DurationSec = 6,
|
||
OperationStartDepth = 206,
|
||
OperationEndDepth = 206,
|
||
IsWellDepthIncreasing = false,
|
||
IsWellDepthDecreasing = false,
|
||
IsBitPositionIncreasing = true,
|
||
IsBitPositionDecreasing = false,
|
||
IsBitPositionLt20 = true,
|
||
IsBlockPositionIncreasing = true,
|
||
IsBlockPositionDecreasing = false,
|
||
IsRotorSpeedLt3 = true,
|
||
IsRotorSpeedGt3 = false,
|
||
IsPressureLt20 = true,
|
||
IsPressureGt20 = false,
|
||
IsHookWeightNotChanges = true,
|
||
IsHookWeightLt3 = true
|
||
},
|
||
new TelemetryAnalysis
|
||
{
|
||
Id = 3,
|
||
IdTelemetry = 1,
|
||
IdOperation = 10,
|
||
UnixDate = 1626870370,
|
||
DurationSec = 2,
|
||
OperationStartDepth = 206,
|
||
OperationEndDepth = 206,
|
||
IsWellDepthIncreasing = false,
|
||
IsWellDepthDecreasing = false,
|
||
IsBitPositionIncreasing = false,
|
||
IsBitPositionDecreasing = true,
|
||
IsBitPositionLt20 = true,
|
||
IsBlockPositionIncreasing = false,
|
||
IsBlockPositionDecreasing = true,
|
||
IsRotorSpeedLt3 = true,
|
||
IsRotorSpeedGt3 = false,
|
||
IsPressureLt20 = true,
|
||
IsPressureGt20 = false,
|
||
IsHookWeightNotChanges = true,
|
||
IsHookWeightLt3 = true
|
||
},
|
||
new TelemetryAnalysis
|
||
{
|
||
Id = 4,
|
||
IdTelemetry = 1,
|
||
IdOperation = 17,
|
||
UnixDate = 1626870372,
|
||
DurationSec = 7,
|
||
OperationStartDepth = 206,
|
||
OperationEndDepth = 206,
|
||
IsWellDepthIncreasing = false,
|
||
IsWellDepthDecreasing = false,
|
||
IsBitPositionIncreasing = false,
|
||
IsBitPositionDecreasing = false,
|
||
IsBitPositionLt20 = true,
|
||
IsBlockPositionIncreasing = false,
|
||
IsBlockPositionDecreasing = false,
|
||
IsRotorSpeedLt3 = true,
|
||
IsRotorSpeedGt3 = false,
|
||
IsPressureLt20 = true,
|
||
IsPressureGt20 = false,
|
||
IsHookWeightNotChanges = true,
|
||
IsHookWeightLt3 = true
|
||
},
|
||
new TelemetryAnalysis
|
||
{
|
||
Id = 5,
|
||
IdTelemetry = 1,
|
||
IdOperation = 8,
|
||
UnixDate = 1626870379,
|
||
DurationSec = 7,
|
||
OperationStartDepth = 206,
|
||
OperationEndDepth = 206,
|
||
IsWellDepthIncreasing = false,
|
||
IsWellDepthDecreasing = false,
|
||
IsBitPositionIncreasing = true,
|
||
IsBitPositionDecreasing = false,
|
||
IsBitPositionLt20 = true,
|
||
IsBlockPositionIncreasing = true,
|
||
IsBlockPositionDecreasing = false,
|
||
IsRotorSpeedLt3 = true,
|
||
IsRotorSpeedGt3 = false,
|
||
IsPressureLt20 = true,
|
||
IsPressureGt20 = false,
|
||
IsHookWeightNotChanges = true,
|
||
IsHookWeightLt3 = true
|
||
}
|
||
});
|
||
});
|
||
}
|
||
|
||
public IQueryable<Well> GetWellsForCompany(int idCompany)
|
||
{
|
||
return from well in Wells
|
||
.Include(w => w.RelationCompaniesWells)
|
||
.ThenInclude(r => r.Company)
|
||
.Include(w => w.Cluster)
|
||
.ThenInclude(c => c.Deposit)
|
||
where well.RelationCompaniesWells.Any(c => c.IdCompany == idCompany)
|
||
select well;
|
||
}
|
||
|
||
public IQueryable<User> GetUsersByLogin(string login)
|
||
=> Users
|
||
.Include(e => e.Role)
|
||
.Include(e => e.Company)
|
||
.Where(e => e.Login == login);
|
||
|
||
public async Task<(DateTime From, DateTime To)> GetDatesRangeAsync<TEntity>(int idTelemetry,
|
||
CancellationToken token = default)
|
||
where TEntity : class, IIdTelemetryDate
|
||
{
|
||
var dbSet = Set<TEntity>();
|
||
|
||
var datesRange = await (from m in dbSet
|
||
where m.IdTelemetry == idTelemetry
|
||
group m by m.IdTelemetry into g
|
||
select new
|
||
{
|
||
From = g.Min(d => d.Date),
|
||
To = g.Max(d => d.Date)
|
||
}).AsNoTracking().FirstOrDefaultAsync(token);
|
||
|
||
if (datesRange is null)
|
||
return (DateTime.MinValue, DateTime.MaxValue);
|
||
|
||
return (datesRange.From, datesRange.To);
|
||
}
|
||
|
||
public async Task<IEnumerable<(double? MinDepth, double? MaxDepth, DateTime BeginPeriodDate)>> GetDepthToIntervalAsync(int telemetryId,
|
||
int intervalHoursTimestamp, int workStartTimestamp, double timezoneOffset, CancellationToken token)
|
||
{
|
||
//TODO: Сменить на LINQ группирование
|
||
using var command = Database.GetDbConnection().CreateCommand();
|
||
|
||
command.CommandText = $@"SELECT Min(t.bit_depth) AS MinDepth, Max(t.bit_depth) AS MaxDepth, Min(t.Date) AS dateStart
|
||
FROM t_data_saub_base AS t
|
||
WHERE id_telemetry = {telemetryId} AND t.Id % 10 = 0
|
||
GROUP BY floor((extract(epoch from t.date) - {workStartTimestamp} + {timezoneOffset}) / {intervalHoursTimestamp});";
|
||
|
||
Database.OpenConnection();
|
||
using var reader = await command.ExecuteReaderAsync(token);
|
||
|
||
IEnumerable<(double? MinDepth, double? MaxDepth, DateTime BeginPeriodDate)> GetResult(DbDataReader rd)
|
||
{
|
||
if (rd.HasRows)
|
||
{
|
||
while (reader.Read())
|
||
{
|
||
yield return
|
||
(
|
||
(double?)reader.GetValue(0),
|
||
(double?)reader.GetValue(1),
|
||
(DateTime)reader.GetValue(2)
|
||
);
|
||
}
|
||
}
|
||
}
|
||
|
||
return GetResult(reader);
|
||
}
|
||
|
||
public async Task<int> CreatePartitionAsync<TEntity>(string propertyName, int id, CancellationToken token = default)
|
||
where TEntity : class
|
||
{
|
||
var dbSet = Set<TEntity>();
|
||
var baseTableName = dbSet.EntityType.GetTableName();
|
||
var schema = dbSet.EntityType.GetSchema();
|
||
var tableObject = Microsoft.EntityFrameworkCore.Metadata.StoreObjectIdentifier.Table(baseTableName, schema);
|
||
var tableName = baseTableName.Replace("_base", "");
|
||
var property = dbSet.EntityType.GetProperty(propertyName).GetColumnName(tableObject);
|
||
|
||
var query = $"CREATE TABLE {tableName}_{id} (like {baseTableName} including all, constraint partitioning_check check ({property} = 1)) INHERITS ({baseTableName});";
|
||
|
||
return await Database.ExecuteSqlRawAsync(query, token).ConfigureAwait(false);
|
||
}
|
||
}
|
||
}
|