|
Hey Reader, In today’s tutorial, I’ll walk you through how to use Dapper, a high-performance micro ORM (object-relational mapper) with a .NET 8 Web API and SQL Server. We’ll cover everything you need to know to build a simple CRUD (Create, Read, Update, Delete) application. Watch on YouTube 📺Check out the full tutorial on YouTube to see everything in action 👇 What We’ll Be DoingWe’re going to work with a simple video game database to start. You’ll learn how to:
First, we’ll set up our Web API using Visual Studio, configure the project, and add Dapper as a NuGet package. Once everything's set, we’ll create a model for our video games that mirrors the database structure: ID, title, publisher, developer, and release date. Next up, you’ll see how to establish a connection to the SQL Server using a connection string in the Why Dapper?Dapper gives you full control over your SQL queries. While it doesn’t auto-generate queries like Entity Framework, Dapper ensures everything stays efficient and lightweight, making it ideal for high-performance apps. Plus, if you're working in an environment where you're dealing with an existing database or a team that handles the database design, Dapper might be perfect for you! Step-by-Step Guide1. Set up the Project:First, let's create a new ASP.NET Core Web API project in Visual Studio. Make sure to select .NET 8. 2. Install Dapper:In the NuGet Package Manager, search for and install 3. Create a Video Game Model:Add a new folder called 4. Add a Connection String:Next, open the 5. Create a Repository Interface:Add a new folder called 6. Create the Repository Implementation:Now, create a class that implements the First, we inject IConfiguration, so that we get access to the connection string from the appsettings.json file. It is necessary to create a connection to the database each time we want to run a query. We also add a little function to create the connection whenever we need it. Next, we implement all the CRUD operations. Let's start with the easy one, receiving all video games. Let's also create the VideoGamesController and add the corresponding GET method there. Last step is registering the repository in the Program.cs. Now we can run the application and test the first call with Swagger. Awesome! Now, let's continue with the other CRUD operations - receiving a single video game, adding a video game, updating and deleting one. Please note, that we're using parameters here. Otherwise, we would risk SQL injection attacks. Don't forget the corresponding controller methods. Wrapping UpNow you have a fully functional API that can interact with a SQL Server database using Dapper. You understand how to fetch data from the database, add new records, update existing ones, and delete records you no longer need. What's your experience with Dapper? Is it your goto tool in your projects or would you rather use Entity Framework or something else? Happy coding and have an awesome weekend! Take care, Patrick PS: Need help understanding .NET & Blazor? There are two ways I can help you with:
PPS: Would you like to sponsor this newsletter? Click here. 💌 |
Become a .NET & Blazor expert with weekly tutorials featuring best practices and the latest improvements, right in your inbox.
Hey friend, The other day I found a bug in StackBuddy, an app I built. Normally I'd open it, file a ticket for myself, and move on. Instead I turned to my AI and just said, "log a dev ticket for that." And it did. A real ticket in my own bug tracker. Title, description, priority, the whole thing. I never opened the actual app. The thing that makes that possible is called MCP, Model Context Protocol. Ignore the name for a second. Out of the box, an AI can only talk. It writes and explains, but...
Hey friend, I don't really write code by hand anymore. I describe what I want, and the AI builds it. For a while, that scared me. If I am not writing the code, does everything I spent years learning still matter? Does my stack matter at all? If you are a developer right now, I would bet you have felt some version of that too. Here is where I landed. It flipped the whole thing for me. The other day I was debugging a slow app, talking it through with the AI. Would WebAssembly help here? Is it...
Hey friend, Lately I told an AI I’d see it in 7 hours, and went to bed. It was done in 2. Across two different projects. There’s this thing people call the night shift. You give an AI agent a pile of work, start it in a loop, and go to sleep while it keeps working on your real codebase. I tried it a month ago and could not make it work, the model just fell apart. But with the newest models, it works now. And the surprising part wasn’t that it ran all night. It’s that it ran out of work before...