C#中怎么访问postgresql数据库
发表于:2025-12-03 作者:千家信息网编辑
千家信息网最后更新 2025年12月03日,这篇文章给大家介绍C#中怎么访问postgresql数据库,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。为了访问PostgreSQL数据库,需要采用Npgsql包,.Net Da
千家信息网最后更新 2025年12月03日C#中怎么访问postgresql数据库
这篇文章给大家介绍C#中怎么访问postgresql数据库,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
为了访问PostgreSQL数据库,需要采用Npgsql包,.Net Data Provider for Postgresql的组件。在C#中通过调用这个封装好的库来访问PostgreSQL。
解压缩zip文件,把解压缩的目录中的Npgsql.dll、Mono.Security.dll复制到C#工程的obj目录下,然后在VS2008中,把 Npgsql.dll文件加入到References。
在需要使用Npgsql的C#文件头,加入如下的using语句。
using Npgsql;
创建一个PostgreSQL的数据库连接
/* 用指定的connectionString,去实例化一个NpsqlConnection的对象*/ string connectionString = "Server=127.0.0.1;Port=5432;User Id=test;Password=test;Database=testdb;" NpgsqlConnection conn = new NpgsqlConnection(string connectionString); // 打开一个数据库连接,在执行相关SQL之前调用 conn.Open(); //关闭一个数据库连接,在执行完相关SQL之后调用 conn.Close(); /* 用指定的connectionString,去实例化一个NpsqlConnection的对象*/string connectionString = "Server=127.0.0.1;Port=5432;User Id=test;Password=test;Database=testdb;"NpgsqlConnection conn = new NpgsqlConnection(string connectionString);// 打开一个数据库连接,在执行相关SQL之前调用conn.Open();//关闭一个数据库连接,在执行完相关SQL之后调用conn.Close();
用NpgsqlCommand.ExecuteScalar()方法获得唯一值的检索结果
try { string sql = "select count(*) from test"; conn.Open(); NpgSqlCommand objCommand = new NpgSqlCommand(sql, conn); int count = Convert.ToInt32(objCommand.ExecuteScalar()); } finally { conn.Close(); } try{string sql = "select count(*) from test";conn.Open();NpgSqlCommand objCommand = new NpgSqlCommand(sql, conn);int count = Convert.ToInt32(objCommand.ExecuteScalar());}finally{conn.Close();}用NpgsqlCommand.ExecuteReader() 方法获得一个结果集的检索结果(conn的Open和Close调用省略)
string sql = "select * from test"; NpgsqlCommand objCommand = new NpgsqlCommand(sql,conn); NpgsqlDataReader dr = command.ExecuteReader(); while(dr.Read()) { for (i = 0; i < dr.FieldCount; i++) { Console.Write("{0} \t", dr[i]); //获得字段名 } int testId = dr["id"]; // 获得指定字段的值。(id是test表的一个字段) …… Console.WriteLine(); } dr.Close(); string sql = "select * from test";NpgsqlCommand objCommand = new NpgsqlCommand(sql,conn);NpgsqlDataReader dr = command.ExecuteReader();while(dr.Read()){for (i = 0; i < dr.FieldCount; i++){Console.Write("{0} \t", dr[i]); //获得字段名}int testId = dr["id"]; // 获得指定字段的值。(id是test表的一个字段)……Console.WriteLine();}dr.Close();用NpgsqlCommand.ExecuteNonQuery()方法对指定表进行添加、更新和删除一条记录的操作
添加记录:string sql = "insert test values (1,200)"; NpgsqlCommandobjCommand = new NpgsqlCommand(sql, conn); objCommand.ExecuteNonQuery(); string sql = "insert test values (1,200)";NpgsqlCommandobjCommand = new NpgsqlCommand(sql, conn);objCommand.ExecuteNonQuery();更新记录sql = "update test set price=300 where id=1"; NpgsqlCommandobjCommand = new NpgsqlCommand(sql, conn); objCommand.ExecuteNonQuery(); sql = "update test set price=300 where id=1";NpgsqlCommandobjCommand = new NpgsqlCommand(sql, conn);objCommand.ExecuteNonQuery();删除记录sql = "delete from test where id=1"; NpgsqlCommandobjCommand = new NpgsqlCommand(sql, conn); objCommand.ExecuteNonQuery(); sql = "delete from test where id=1";NpgsqlCommandobjCommand = new NpgsqlCommand(sql, conn);objCommand.ExecuteNonQuery();
用NpgsqlDataAdapter.Fill方法,把检索的结果集放到DataSet object中,这样可以使用DataSet object设置。DotNet的DataGridView控件的DataSource属性,这样在DataGridView中显示从表中取出的所有记录。
string sql = "select id,price from test"; DataSet ds = new DataSet(); NpgsqlDataAdapter objAdapter = new NpgsqlDataAdapter(sql, conn); objAdapter.Fill(ds, "a"); //"a"这个表是自定义的 dgvBaseResult.DataSource = ds.Tables["a"]; //dgvBaseResult是DataGridView的一个Object。 string sql = "select id,price from test";DataSet ds = new DataSet();NpgsqlDataAdapter objAdapter = new NpgsqlDataAdapter(sql, conn);objAdapter.Fill(ds, "a"); //"a"这个表是自定义的dgvBaseResult.DataSource = ds.Tables["a"]; //dgvBaseResult是DataGridView的一个Object。注:SQL语句设置也可以用下面的语句 objAdapter.SelectCommand.CommandText = sql;
关于C#中怎么访问postgresql数据库就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
数据
数据库
字段
C#
方法
结果
文件
语句
检索
内容
实例
对象
更多
目录
帮助
更新
不错
兴趣
小伙
小伙伴
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全目标五要素
数据库当中非负且非空怎么表示
内蒙古知名软件开发报价
软件开发招来的人当天就走
堡垒机 数据库访问控制
火影忍者砂铁服务器
日常网络安全管理工作
数据库应用系统的使用
考勤机怎样设置云服务器地址
数据库选题背景和意义
我们也与警察谈论网络安全翻译
把服务器装进笔记本
网络安全防守指南
网络安全应急处置办法
合肥万户网络技术有限
软件开发后数据怎么保存
仙境传说装备数据库
ue4专用服务器开发
自动化药房网络安全方案
做软件开发应该选什么专业
考研数据库系统原理复试问答
无锡宝通科技有限公司互联网
南昌狼派互联网科技有限公司
软件开发英语文献
server服务器总提示警告
数据库类型是否
腾讯软件开发微博
2021信创数据库名单
手机怎样设置网络安全
党领导下的网络安全