rollenspiel.social ist einer von vielen unabhängigen Mastodon-Servern, mit dem du dich im Fediverse beteiligen kannst.
rollenspiel.social wird von RollenspielMonster bereitgestellt. Wir bieten einen Platz für Rollenspiel, Pen & Paper, Tabletop, TCG und vieles mehr. Die primäre Sprache ist Deutsch.

Verwaltet von:

Serverstatistik:

538
aktive Profile

#designpatterns

0 Beiträge0 Beteiligte0 Beiträge heute

Have you heard of the observer pattern?

The observer design pattern is one of the patterns we're often exposed to early on in programming.

This pattern allows observers to observe observables.
(Clear as mud, right?)

Said another way, the different components of your system can listen for notifications, changes, and events by following this pattern!

Check out the article:
devleader.ca/2023/11/17/exampl

#csharp#dotnet#dotnetcore

Have you ever dreaded writing the same boilerplate repository code repeatedly? You’re not alone; I will share my implementation of the Code First Generic Repository Pattern in C#. I will only include some of the code because it will make the post incredibly long. At the end of the post, I will share a Goal donation to post a Git download link so you can take it for a spin. As a bonus, the repository uses Code First and Unit of Work.

Generic Repository Pattern in C#

Let’s begin with the Entity interface. The IEntity interface is a typical pattern used in software development to define a contract for entities, typically in the context of data access and persistence. It usually includes a property for the entity’s unique identifier. The Generic Type: The IEntity interface uses a generic type parameter TKey to allow flexibility in the type of the identifier (e.g., int, Guid, string). The ID property will identify each entity uniquely. Feel free to read more about the implementation at the entity framework core generic repository and Structured Query IEntity.

public interface IEntity<TKey>{    TKey Id { get; set; }}

You might find the following definition of the generic repository pattern on the interwebs.

The Generic Repository pattern in C# is a design pattern that abstracts the application’s data layer, making it easier to manage data access logic across different data sources. It aims to reduce redundancy by implementing typical data operations in a single, generic repository rather than having separate repositories for each entity type.

public interface IGenericRepository<TEntity, TKey> where TEntity : class, IEntity<TKey>{    void Delete(TEntity entityToDelete);    TEntity? GetFirstOrDefault(Expression<Func<TEntity, bool>> predicate);    void Update(TEntity entityToUpdate);    void Save();    void Dispose();}

The interface header has two generic types. TEntity is the domain class, and the TKey is the ID type, int, or string. Note that IEntity abstracts away the type TKey. It looks complex for the moment, but you will see benefits later.

Moving away from the Generic Repository, let’s focus on the pattern of the Unit of Work. According to Copilot:

The Unit of Work is a design pattern used in software development to manage and coordinate changes to a database. It ensures that all operations within a single business transaction are treated as a single unit, which means they either all succeed, or all fail together. This helps maintain data integrity and consistency.

Implementing the Repository and Unit of Work Patterns in an ASP.NET MVC Application (9 of 10) | Microsoft Learn

https://code-maze.com/csharp-unit-of-work-pattern/

public interface IUnitOfWork : IDisposable{    IGenericRepository<TEntity, TKey> Repository<TEntity, TKey>() where TEntity : class, IEntity<TKey>;    void Save();    Task<int> SaveAsync();}

The Unit of Work will allow us later to inject it as a service for any repository. If you inspect the interface closely, you will notice it has three fields. The most vital of the three is the Repository. The method returns a domain of type repository and key. You can specify the type when using it.

Moving on to the Code First portion, we must tell Entity Framework how to build our database. To do so, we can create a “BloggingContext”.

public class BloggingContext: DbContext{    // Use design time factory    public BloggingContext(DbContextOptions<BloggingContext> dbContextOptions)    : base(dbContextOptions)    {    }    public DbSet<Blog> Blogs { get; set; }    public DbSet<Post> Posts { get; set; }}

If you inspect the code closely, you will notice that we inherited from DbContext, which allows us to manipulate the database. The DbContext will also enable us to use DbSets and CRUD methods. You can read more about DbContext Class on the Microsoft website.

Before using your Database Context with Code, you must set up migrations. Migrations allow you to evolve your database as you code and change the schema. I recommend you read up on Migrations managing schemas because it has excellent examples to help you start quickly.

At the high level, in Visual Studio, open up the Tools menu, then the NuGet Package Manager menu, followed by the Console. In the Console, you must install the following package.

Install-Package Microsoft.EntityFrameworkCore.Tools

The Microsoft.EntityFrameworkCore.Tools will allow you to make the following commands.

Add-Migration InitialCreate

Update-Database

Meanwhile, you might want to consider making a DesignTimeDbContextFactory because it aids in setting up the connection string for the database.

public class DesignTimeDbContextFactory : IDesignTimeDbContextFactory<BloggingContext>{    public BloggingContext CreateDbContext(string[] args)    {        // Build configuration        IConfigurationRoot configuration = new ConfigurationBuilder()            .SetBasePath(Directory.GetCurrentDirectory())            .AddJsonFile("appsettings.Development.json")            .Build();        // Get connection string        var connectionString = configuration.GetConnectionString("DefaultConnection");        var optionsBuilder = new DbContextOptionsBuilder<BloggingContext>();        optionsBuilder.UseSqlServer(connectionString);        return new BloggingContext(optionsBuilder.Options);    }}

I’m considering publishing the fully working example on Git with the following components.

  • Services
  • Domain
  • Interfaces
  • Repository
  • Console App with basic CRUD operations
  • Dependency Injection

Current Donation Amount

$2.41 – PayPal fees 🤑

Note that the donation amount is being updated manually on my end. I have asked WordPress; see the image for details. I will list your name and last name initials. If you like the website backlink, donate $10 or more, and let me know in the comments your web address.

Donate to Goal of $666 to unlock Code First Generic Repository Pattern 🚀✨

Upon reaching the $666 Goal, I will share the code.

$3.00

Click here to purchase.

Donators List

  • Nicholas S 8.20.2024

https://vyechi.com/2024/08/20/generic-repository-pattern-in-c/

Dear #Fediverse, I ask you for #help 🌌

Recommend me some #books to buy on 📚
#Python (language)
#Django
#Accessibility (#web)
#PostgreSQL
#ArtificialIntelligence
#DesignPatterns
#FreeSoftware
#OpenSource

I'd like to have 🪪
• author
• title
• suggestion reason
• purchase URL

I prefer #ePUB (more than Amazon and content with DRM), but #paperback is fine if there are no alternatives ✨

Thank you 🙏

P.S. It's fine to propose books that you've written 👍

P.P.S. #boost please 🔁