C#訪問PostGreSQL數(shù)據(jù)庫的方法
我對PostGreSQL只是一知半解,記錄這個(gè)過程是希望如果以后微軟技術(shù)方向的人遇到類似的需求,可以有個(gè)比較直接的的參考。
在不熟悉的知識(shí)領(lǐng)域里,總是有搜索引擎可以幫到我。
初步了解PostGreSQL數(shù)據(jù)庫及數(shù)據(jù)形態(tài)
首先我想看看PostGreSQL的數(shù)據(jù)庫以及我想要獲取的數(shù)據(jù)形態(tài)是什么樣子的,Linux和PostGreSQL這兩個(gè)關(guān)鍵字我都不熟悉,搜了一下找到了一個(gè)可以連通PostGreSQL數(shù)據(jù)庫的Windows客戶端,叫pgAdmin,我裝的是III版本,應(yīng)該是比較新的,下載安裝后看到界面:

點(diǎn)擊那個(gè)電源插頭的logo可以新建服務(wù)器連接
名稱就是在PGAdmin客戶端的顯示名,可以自定義。
SSL呢,有這么多選項(xiàng),我不是很了解干什么用的,反正我選的允許。

端口號,默認(rèn)PostGreSQL的端口號是5432,當(dāng)然可以被修改,自定義成別的端口號
全部填寫完點(diǎn)擊確定,就可以看到數(shù)據(jù)庫了。
我不在客戶現(xiàn)場,連不上PostGreSQL的庫,所以下面就不能截圖了。

在PGAdmin里,可以寫查詢語句,如果你有權(quán)限的話,可以看到返回的結(jié)果集。
我點(diǎn)開一個(gè)窗口,試著寫了一條查詢語句如下:
Select top 10 * from TableObj
執(zhí)行,發(fā)現(xiàn)結(jié)果集窗口提示語法錯(cuò)誤,問下群里的兄弟們,得知,正確的寫法應(yīng)該是這樣的:
Select * from TableObj limit 5
語法規(guī)則跟sql語句還是有區(qū)別的。
執(zhí)行,提示找不到對象“TableObj”找到TableObj的上一層容器“ContainerObj”,修改如下
SELECT* FROM ContainerObj.TableObj limit 5
點(diǎn)擊執(zhí)行,終于看到了結(jié)果集。
相對sqlserver來說,PGAdmin的結(jié)果集顯示界面表頭都有兩行,一行是字段名,一行是字段的數(shù)據(jù)類型。這點(diǎn)很有愛。
在PostGreSQL的查詢語句中,大小寫是不敏感的。
關(guān)于PostgreSql語法規(guī)則,在CSDN上找到了《PostgreSql語法詳細(xì)手冊》,不過這家伙要三個(gè)資源分。
好了看到PostGreSQL數(shù)據(jù)庫了,下面我要嘗試敲C#代碼測試去取PostGreSQL的數(shù)據(jù)。
C#連接PostGreSQL數(shù)據(jù)庫
有個(gè)東東,叫Npgsql,是PostgreSQL的一個(gè).NET數(shù)據(jù)提供程序。首先需要下載它,實(shí)際上我們只需要引用兩個(gè)dll:

經(jīng)過我的測試,如果只引用了Npgsql.dll,那么你的程序運(yùn)行起來之后會(huì)報(bào)錯(cuò),提示找不到對Mono.Security.dll引用的依賴項(xiàng)。
引用了這兩個(gè)dll,你還需要在你的代碼中加上using。
using Npgsql;
代碼就很簡單了。
寫了個(gè)拼字符串的,比較二。txt什么什么的都是Winform的textbox
///
/// 根據(jù)填寫的信息拼數(shù)據(jù)庫連接串
///
/// 數(shù)據(jù)庫連接串
private string getConnectStr()
{
StringBuilder sb = new StringBuilder();
string str = string.Empty;
sb.Append("Server=");
sb.Append(txtServer.Text);
sb.Append(";Port=");
sb.Append(txtPort.Text);
sb.Append(";User Id=");
sb.Append(txtUID.Text);
sb.Append(";Password=");
sb.Append(txtPassword.Text);
sb.Append(";Database=");
sb.Append(txtDB.Text);
sb.Append(";");
str = sb.ToString();
return str;
}
實(shí)際上數(shù)據(jù)庫連接串就是這么樣的一個(gè)格式
"Server=192.168.1.100;Port=5432;UserId=mike;Password=secret;Database=mikedb;"
///
/// 測試連接PostGreSQL數(shù)據(jù)庫
///
/// Success/Failure
private string TestConnection()
{
string str = getConnectStr();
string strMessage = string.Empty;
try
{
NpgsqlConnection conn = new NpgsqlConnection(str);
conn.Open();
strMessage = "Success";
conn.Close();
}
catch
{
strMessage = "Failure";
}
return strMessage;
}
///
/// 測試獲取數(shù)據(jù)(使用要加try、catch)
///
private void TestGetData()
{
IDbConnection dbcon;
dbcon = newNpgsqlConnection(getConnectStr());
dbcon.Open();
IDbCommand dbcmd = dbcon.CreateCommand();
dbcmd.CommandText = " SELECT * FROM ContainerObj.TableObj limit 5";
IDataReader dr = dbcmd.ExecuteReader();
string strResult = string.Empty;
while (dr.Read())
{
stringstrRecord_Time_Int = dr[0].ToString();
stringstrIP = dr[1].ToString();
stringstrFullPath = dr[2].ToString();
stringstrUpload_Size = dr[3].ToString();
stringstrDownLoad_Size = dr[4].ToString();
strResult += "record_time_int: " + strRecord_Time_Int+ " | ip:" + strIP + " | fullpath:" +strFullPath + " | upload_size:" +strUpload_Size + " | download_size:"+ strDownLoad_Size + "\n";
}
dr.Close();
dr = null;
lblRes.Text = strResult;
}
Form很簡單,只為測試功能。下面截圖是之前在現(xiàn)場截的,處理了一下,隱去了一些信息。

相關(guān)文章
淺析C#?AsyncLocal如何在異步間進(jìn)行數(shù)據(jù)流轉(zhuǎn)
在異步編程中,處理異步操作之間的數(shù)據(jù)流轉(zhuǎn)是一個(gè)比較常用的操作,C#異步編程提供了一個(gè)強(qiáng)大的工具來解決這個(gè)問題,那就是AsyncLocal,下面我們就來看看AsyncLocal的原理和用法吧2023-08-08
Unity實(shí)現(xiàn)紅酒識(shí)別的示例代碼
本文主要介紹了如何通過Unity實(shí)現(xiàn)紅酒識(shí)別,可以實(shí)現(xiàn)識(shí)別圖像中的紅酒標(biāo)簽,返回紅酒名稱、國家、產(chǎn)區(qū)、酒莊、類型、糖分、葡萄品種、酒品描述等信息,感興趣的可以學(xué)習(xí)一下2022-02-02
C#中把Datatable轉(zhuǎn)換為Json的5個(gè)代碼實(shí)例
這篇文章主要介紹了C#中把Datatable轉(zhuǎn)換為Json的5個(gè)代碼實(shí)例,需要的朋友可以參考下2014-04-04
Unity實(shí)現(xiàn)繞任意軸任意角度旋轉(zhuǎn)向量
這篇文章主要為大家詳細(xì)介紹了Unity實(shí)現(xiàn)繞任意軸任意角度旋轉(zhuǎn)向量,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-01-01
C#下實(shí)現(xiàn)創(chuàng)建和刪除目錄的實(shí)例代碼
這篇文章主要介紹了C#下實(shí)現(xiàn)創(chuàng)建和刪除目錄的方法,功能非常實(shí)用,需要的朋友可以參考下2014-08-08

