MySqlDbContext.cs 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Reflection;
  5. using System.ComponentModel.DataAnnotations.Schema;
  6. using Microsoft.EntityFrameworkCore;
  7. using YiSha.Util;
  8. namespace YiSha.Data.EF
  9. {
  10. public class MySqlDbContext : DbContext, IDisposable
  11. {
  12. private string ConnectionString { get; set; }
  13. public MySqlDbContext(string connectionString)
  14. {
  15. ConnectionString = connectionString;
  16. }
  17. #region 重载
  18. protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
  19. {
  20. optionsBuilder.UseMySql(ConnectionString, p => p.CommandTimeout(GlobalContext.SystemConfig.DBCommandTimeout));
  21. optionsBuilder.AddInterceptors(new DbCommandCustomInterceptor());
  22. }
  23. protected override void OnModelCreating(ModelBuilder modelBuilder)
  24. {
  25. Assembly entityAssembly = Assembly.Load(new AssemblyName("YiSha.Entity"));
  26. IEnumerable<Type> typesToRegister = entityAssembly.GetTypes().Where(p => !string.IsNullOrEmpty(p.Namespace))
  27. .Where(p => !string.IsNullOrEmpty(p.GetCustomAttribute<TableAttribute>()?.Name));
  28. foreach (Type type in typesToRegister)
  29. {
  30. dynamic configurationInstance = Activator.CreateInstance(type);
  31. modelBuilder.Model.AddEntityType(type);
  32. }
  33. foreach (var entity in modelBuilder.Model.GetEntityTypes())
  34. {
  35. PrimaryKeyConvention.SetPrimaryKey(modelBuilder, entity.Name);
  36. string currentTableName = modelBuilder.Entity(entity.Name).Metadata.GetTableName();
  37. modelBuilder.Entity(entity.Name).ToTable(currentTableName);
  38. //var properties = entity.GetProperties();
  39. //foreach (var property in properties)
  40. //{
  41. // ColumnConvention.SetColumnName(modelBuilder, entity.Name, property.Name);
  42. //}
  43. }
  44. base.OnModelCreating(modelBuilder);
  45. }
  46. #endregion
  47. }
  48. }