Files
PersonSport/Models/IdrottContext.cs
2026-03-05 15:43:26 +01:00

36 lines
1.5 KiB
C#

using Microsoft.EntityFrameworkCore;
using System.Linq;
namespace PersonSport.Models {
public class IdrottContext : DbContext {
public DbSet<Person> Personer { get; set; }
public DbSet<Sport> Sporter { get; set; }
public DbSet<Admin> Administratorer { get; set; }
protected override void OnConfiguring(DbContextOptionsBuilder options)
// Azure
// => options.UseSqlite("FileName=C:/Users/ChristianOhlsson(HV)/OneDrive - Högskolan Väst/skola/Databasteknik och webbaserade system [Umeå HT21]/Projektarbete/PersonSport/Data/PersonSport.db");
// Lokalt
=> options.UseSqlite("DataSource=./Data/PersonSport.db");
protected override void OnModelCreating(ModelBuilder modelBuilder) {
modelBuilder.Entity<PersonSport>()
.HasKey(c => new { c.PersonId, c.SportId });
modelBuilder.Entity<Person>()
.HasMany(c => c.PersonSporter);
modelBuilder.Entity<Sport>()
.HasMany(c => c.PersonSporter);
// Tar bort "ON DELETE CASCADE" så att inte sporten försvinner om sista personen
// som utövar den gör det.
base.OnModelCreating(modelBuilder);
foreach (var relationship in modelBuilder.Model.GetEntityTypes().SelectMany(e => e.GetForeignKeys())) {
relationship.DeleteBehavior = DeleteBehavior.Restrict;
}
}
}
}