| | 1 | | using Domain.Entities; |
| | 2 | | using Microsoft.EntityFrameworkCore; |
| | 3 | | using Microsoft.EntityFrameworkCore.Metadata.Builders; |
| | 4 | |
|
| | 5 | | namespace Repository.Mapping; |
| | 6 | | public class ReceitaMap : IEntityTypeConfiguration<Receita> |
| | 7 | | { |
| | 8 | | public void Configure(EntityTypeBuilder<Receita> builder) |
| 3 | 9 | | { |
| 3 | 10 | | builder.ToTable(nameof(Receita)); |
| 3 | 11 | | builder.Property(r => r.Id) |
| 3 | 12 | | .HasColumnType("varchar(36)") |
| 3 | 13 | | .HasConversion(v => v.ToString(), v => new Guid(v)) |
| 3 | 14 | | .ValueGeneratedOnAdd() |
| 3 | 15 | | .IsRequired(); |
| 3 | 16 | | builder.HasKey(r => r.Id); |
| 3 | 17 | | builder.Property(r => r.UsuarioId) |
| 3 | 18 | | .HasColumnType("varchar(36)") |
| 3 | 19 | | .HasConversion(v => v.ToString(), v => new Guid(v)) |
| 3 | 20 | | .ValueGeneratedOnAdd() |
| 3 | 21 | | .IsRequired(); |
| 3 | 22 | | builder.Property(r => r.Descricao).IsRequired(false).HasMaxLength(100); |
| 3 | 23 | | builder.Property(r => r.CategoriaId) |
| 3 | 24 | | .HasColumnType("varchar(36)") |
| 3 | 25 | | .HasConversion(v => v.ToString(), v => new Guid(v)).ValueGeneratedOnAdd().IsRequired(); |
| | 26 | |
|
| | 27 | | // MySqlServer |
| 3 | 28 | | builder.Property(m => m.Data).HasColumnType("datetime").HasDefaultValueSql<DateTime>("CURRENT_TIMESTAMP").IsRequ |
| | 29 | |
|
| | 30 | | // MsSqlServer |
| | 31 | | //builder.Property(r => r.Data).HasColumnType("datetime").HasDefaultValueSql<DateTime>("GetDate()").IsRequired() |
| | 32 | |
|
| 3 | 33 | | builder.HasOne(d => d.Categoria) // Receita -> Categoria |
| 3 | 34 | | .WithMany(c => c.Receitas) // Categoria -> Receitas |
| 3 | 35 | | .HasForeignKey(d => d.CategoriaId) |
| 3 | 36 | | .OnDelete(DeleteBehavior.Restrict); |
| | 37 | |
|
| 3 | 38 | | builder.Property(r => r.Valor).HasColumnType("decimal(10, 2)").HasDefaultValue(0); |
| 3 | 39 | | builder.HasOne(r => r.Usuario).WithMany().HasForeignKey(r => r.UsuarioId).OnDelete(DeleteBehavior.NoAction); |
| 3 | 40 | | } |
| | 41 | | } |