C#中怎么访问postgresql数据库
发表于:2025-02-01 作者:千家信息网编辑
千家信息网最后更新 2025年02月01日,这篇文章给大家介绍C#中怎么访问postgresql数据库,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。为了访问PostgreSQL数据库,需要采用Npgsql包,.Net Da
千家信息网最后更新 2025年02月01日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安全错误
数据库的锁怎样保障安全
家政服务app软件开发装
数据库系统及应用教程答案
软件开发开发学习中心
服务器传输文件用什么
云南警官学院网络安全与执法
编程兼职软件开发
临沂大学校园网络技术中心
事业单位 网络技术
查询mysql数据库被锁
零基础c语言软件开发
龙海市网络安全计划
做软件开发读mba有用吗
运维安全数据库密码
天天英雄服务器
什么是数据库主键 什么是视图
热血传奇手游服务器如何配置
云南网络时钟同步服务器云服务器
域服务器扩充网段
银行软件开发和测试岗哪个好
怒江州网络安全宣传周
金水区软件开发专业
生活中数据库应用场景
用友t3 数据库升级
关于网络安全信息化的展台设计
网络安全赛道未来
快速软件开发公司
唐山网络安全审查
始兴软件开发定制
服务器从管理口导出日志
烟台宽视网络技术有限公司