Dapper 操作 PostgreSQL 数据库完全指南

系列文章目录


文章目录


前言

Dapper 是一个高性能的 ORM 框架,可用于简化与数据库的交互。本文将详细介绍如何使用 Dapper 操作 PostgreSQL 数据库,包括连接配置、CRUD 操作以及示例代码。


一、准备工作

首先,确保你的项目中已经添加了 Dapper 和 Npgsql 包。你可以使用以下命令进行安装:

bash 复制代码
dotnet add package Dapper
dotnet add package Npgsql

二、配置数据库连接

在 appsettings.json 中添加 PostgreSQL 数据库连接配置:

json 复制代码
{
  "ConnectionStrings": {
    "DefaultConnection": "Host=localhost;Port=5432;Database=your_database;Username=your_username;Password=your_password;"
  }
}

三、创建数据实体类

创建一个数据实体类,对应数据库中的表:

csharp 复制代码
{
 public class Product
{
    public int Id { get; set; }
    public string Name { get; set; }
    public decimal Price { get; set; }
}

四、实现 CRUD 操作

在业务逻辑层中,通过 Dapper 来实现 CRUD 操作:

csharp 复制代码
using Dapper;
using Microsoft.Extensions.Configuration;
using Npgsql;
using System.Collections.Generic;
using System.Data;
using System.Linq;

namespace YourNamespace
{
    public class ProductService
    {
        private readonly IConfiguration _config;

        public ProductService(IConfiguration config)
        {
            _config = config;
        }

        private IDbConnection Connection => new NpgsqlConnection(_config.GetConnectionString("DefaultConnection"));

        public List<Product> GetAllProducts()
        {
            using IDbConnection dbConnection = Connection;
            dbConnection.Open();
            return dbConnection.Query<Product>("SELECT * FROM products").ToList();
        }

        public Product GetProductById(int id)
        {
            using IDbConnection dbConnection = Connection;
            dbConnection.Open();
            return dbConnection.QueryFirstOrDefault<Product>("SELECT * FROM products WHERE id = @Id", new { Id = id });
        }

        public void InsertProduct(Product product)
        {
            using IDbConnection dbConnection = Connection;
            dbConnection.Open();
            dbConnection.Execute("INSERT INTO products (name, price) VALUES (@Name, @Price)", product);
        }

        public void UpdateProduct(Product product)
        {
            using IDbConnection dbConnection = Connection;
            dbConnection.Open();
            dbConnection.Execute("UPDATE products SET name = @Name, price = @Price WHERE id = @Id", product);
        }

        public void DeleteProduct(int id)
        {
            using IDbConnection dbConnection = Connection;
            dbConnection.Open();
            dbConnection.Execute("DELETE FROM products WHERE id = @Id", new { Id = id });
        }
    }
}

五、使用示例

在控制器中使用 ProductService 进行操作:

csharp 复制代码
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Configuration;
using YourNamespace.Models;
using YourNamespace.Services;

namespace YourNamespace.Controllers
{
    [ApiController]
    [Route("api/[controller]")]
    public class ProductController : ControllerBase
    {
        private readonly ProductService _productService;

        public ProductController(IConfiguration config)
        {
            _productService = new ProductService(config);
        }

        // ... 编写 API 方法,调用 ProductService 中的相应方法
    }
}

总结

通过本文,你已经学会如何使用 Dapper 操作 PostgreSQL 数据库。Dapper 提供了一种轻量级、高性能的数据访问方式,适用于各种类型的项目。希望本文对你在使用 Dapper 进行数据库操作时有所帮助。

如果你有任何问题或疑问,欢迎留言讨论。感谢阅读!

相关推荐
我不介意孤独1 小时前
04-记忆系统为什么向量数据库不够用
数据库·人工智能·资源隔离·agent infra
AOwhisky1 小时前
MySQL 学习笔记(第六期):MySQL 备份与恢复
运维·数据库·笔记·学习·mysql·云计算
qq21084629532 小时前
【数据库】TDengine 清理旧数据
数据库·oracle·tdengine
j_xxx404_2 小时前
MySQL表操作硬核解析:从 CREATE TABLE 到磁盘文件、ALTER TABLE 与 DDL 风险
运维·服务器·数据库·c++·mysql·adb·ai
数据库小学妹2 小时前
PostgreSQL迁移到国产数据库怎么做?评估、改造、上线全流程实操指南
数据库·经验分享·postgresql·dba
x***r1512 小时前
Redis Desktop Manager 0.8.8 安装教程(Windows redis-desktop-manager-0.8.8.384详细步骤)
数据库·windows·redis
initialize13062 小时前
Postgresql(Oracle兼容) 到Oracle19.9字符语义
数据库·oracle
稷下元歌3 小时前
七天学会plc 加机器视觉完整笔记:S7-1200 数据类型、存储区与寻址方式(I/Q/M/DB 详解)。
网络·数据库·笔记
潮起鲸落入海3 小时前
mysql 5.x源码安装
数据库·mysql
睡不醒男孩0308233 小时前
第一篇:多云与多模态时代的企业级数据库云管理平台(DBaaS)选型指南
数据库·clup·中启乘数