.NET C#连接使用PostgreSQL数据库
2024-08-19
227
.NET C#连接PostgreSQL数据库需要使用Npgsql驱动程序。Npgsql是.NET Framework和.NET Core中的一个开源PostgreSQL驱动程序。
要使用Npgsql,需要先在项目中添加引用。可以通过NuGet包管理器来添加引用。在包管理器控制台中,搜索“Npgsql”,然后选择“安装”。
添加引用后,就可以开始连接PostgreSQL数据库了。连接数据库需要以下步骤:
创建一个NpgsqlConnection对象。
设置连接字符串。
打开连接。
连接字符串包含以下信息:
数据库服务器的地址
数据库的端口号
数据库的名称
用户名
密码
连接字符串的格式如下:
Host=<server_address>;Port=<port_number>;Database=<database_name>;Username=<username>;Password=<password>
例如,如果数据库服务器的地址是localhost,端口号是5432,数据库的名称是test,用户名是postgres,密码是123456,则连接字符串为:
Host=localhost;Port=5432;Database=test;Username=postgres;Password=123456
连接数据库的代码如下:
using Npgsql;
class Program
{
static void Main(string[] args)
{
// 创建一个NpgsqlConnection对象
NpgsqlConnection conn = new NpgsqlConnection("Host=localhost;Port=5432;Database=test;Username=postgres;Password=123456");
// 设置连接字符串
conn.ConnectionString = "Host=localhost;Port=5432;Database=test;Username=postgres;Password=123456";
// 打开连接
try
{
conn.Open();
Console.WriteLine("连接成功");
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
// 关闭连接
conn.Close();
}
}
连接成功后,就可以使用Npgsql提供的API来操作数据库了。例如,可以使用NpgsqlCommand对象来执行SQL语句。
执行SQL语句的代码如下:
using Npgsql;
class Program
{
static void Main(string[] args)
{
// 创建一个NpgsqlConnection对象
NpgsqlConnection conn = new NpgsqlConnection("Host=localhost;Port=5432;Database=test;Username=postgres;Password=123456");
// 设置连接字符串
conn.ConnectionString = "Host=localhost;Port=5432;Database=test;Username=postgres;Password=123456";
// 打开连接
try
{
conn.Open();
// 创建一个NpgsqlCommand对象
NpgsqlCommand cmd = new NpgsqlCommand("SELECT * FROM users", conn);
// 执行SQL语句
NpgsqlDataReader reader = cmd.ExecuteReader();
// 遍历结果集
while (reader.Read())
{
// 获取结果集中的字段值
int id = reader["id"].Value<int>();
string name = reader["name"].Value<string>();
int age = reader["age"].Value<int>();
// 输出结果
Console.WriteLine($"id={id}, name={name}, age={age}");
}
// 关闭连接
conn.Close();
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
}
}
以上代码将查询users表中的数据,并将结果输出到控制台。
更新于:5个月前赞一波!4
相关文章
- 【说站】mysql有哪些备份数据库的方式
- .NET C# 使用Hook钩子实现全局监听键盘和鼠标
- BotSharp 基于 .NET 平台的开源 AI 聊天机器人框架
- .NET C#连接FTP实现文件上传下载
- C#使用 Attribute 实现 AOP 功能
- C#中的线程安全的集合ConcurrentQueue使用示例
- 【说站】mysql数据库有哪些调优方法
- .NET C#中的Func、Predicate和Expression用法详解
- 5个高性能 .NET Core 图片处理库推荐
- ASP.NET如何将Views文件夹从项目分离
- C#13新特性 使用System.Threading.Lock简化线程同步
- .NET C# 读取编辑.AVIF图片文件
- .NET C# SkiaSharp读取.AVIF图片文件报错
- .NET开源ORM FreeSql常见问题和解决方法
- 微软于发布了.NET 9 Release Candidate 2 提高整体质量
- 分享5个开源的.NET Excel读写操作库
- ASP.NET 使用Entity Framework (EF) 创建迁移修改SQLite数据库表结构
- 如何从.NET Framework迁移到.NET Core或.NET 6/7?
- 如何优化ASP.NET Core应用的性能?
- 10款.NET开发中推荐的代码分析和质量工具
文章评论
评论问答