using Microsoft.EntityFrameworkCore; using Persistence.Database.Entity; namespace Persistence.Database.Model; public partial class PersistenceDbContext : DbContext { public DbSet DataSaub => Set(); public DbSet ChangeLog => Set(); public DbSet Setpoint => Set(); public DbSet TechMessage => Set(); public DbSet TimestampedSets => Set(); public PersistenceDbContext() : base() { } public PersistenceDbContext(DbContextOptions options) : base(options) { } protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) { if (!optionsBuilder.IsConfigured) optionsBuilder.UseNpgsql("Host=localhost;Database=persistence;Username=postgres;Password=q;Persist Security Info=True;Include Error Detail=True;" //, builder=>builder.EnableRetryOnFailure(2, System.TimeSpan.FromMinutes(1)) ); } protected override void OnModelCreating(ModelBuilder modelBuilder) { modelBuilder.HasPostgresExtension("adminpack") .HasAnnotation("Relational:Collation", "Russian_Russia.1251"); modelBuilder.Entity() .Property(e => e.Set) .HasJsonConversion(); modelBuilder.Entity(entity => { entity.HasOne(t => t.System) .WithMany() .HasForeignKey(t => t.SystemId) .OnDelete(DeleteBehavior.Cascade) .IsRequired(); }); modelBuilder.Entity() .Property(e => e.Value) .HasJsonConversion(); } }