快速入門:使用 .NET (C#) 連線至適用於 PostgreSQL 的 Azure 資料庫 (彈性伺服器) 並查詢其資料
適用範圍:適用於 PostgreSQL 的 Azure 資料庫 - 彈性伺服器
本快速入門示範如何使用 C# 應用程式來連線到適用於 PostgreSQL 的 Azure 資料庫彈性伺服器執行個體。 它會顯示如何使用 SQL 陳述式來查詢、插入、更新和刪除資料庫中的資料。 本文中的步驟假設您已熟悉使用 C# 進行開發,但不熟悉 Azure Database for PostgreSQL 彈性伺服器。
必要條件
在本快速入門中,您需要:
- 具有有效訂用帳戶的 Azure 帳戶。 免費建立帳戶。
- 使用 Azure 入口網站建立「適用於 PostgreSQL 的 Azure 資料庫」彈性伺服器執行個體
如果沒有,請使用 Azure CLI。 - 使用伺服器上可用的空白 postgres 資料庫,或建立新資料庫。
- 安裝適用於您平台的 .NET SDK (英文) (Windows、Ubuntu Linux 或 macOS)。
- 安裝 Visual Studio 以建置您的專案。
- 在 Visual Studio 中安裝 Npgsql NuGet 套件。
取得連線資訊
取得連線到適用於 PostgreSQL 的 Azure 資料庫彈性伺服器執行個體所需的連線資訊。 您需要完整的伺服器名稱和登入認證。
- 登入 Azure 入口網站。
- 從 Azure 入口網站的左側功能表中,按一下 [所有資源],然後搜尋您所建立的伺服器 (例如 mydemoserver)。
- 按一下伺服器名稱。
- 從伺服器的 [概觀] 面板,記下 [伺服器名稱] 和 [伺服器管理員登入名稱]。 如果您忘記密碼,您也可以從此面板重設密碼。
步驟 1:連線和插入資料
使用下列程式碼,以使用 CREATE TABLE 和 INSERT INTO SQL 陳述式來連線和載入資料。 程式碼會使用 NpgsqlCommand 類別搭配下列方法:
- Open() 建立與適用於 PostgreSQL 的 Azure 資料庫彈性伺服器資料庫的連線。
- CreateCommand() 設定 CommandText 屬性。
- ExecuteNonQuery() 方法執行資料庫命令。
重要
以建立伺服器和資料庫時所指定的值,取代主機、資料庫名稱、使用者和密碼參數。
using System;
using Npgsql;
namespace Driver
{
public class AzurePostgresCreate
{
// Obtain connection string information from the portal
//
private static string Host = "mydemoserver.postgres.database.azure.com";
private static string User = "mylogin";
private static string DBname = "postgres";
private static string Password = "<server_admin_password>";
private static string Port = "5432";
static void Main(string[] args)
{
// Build connection string using parameters from portal
//
string connString =
String.Format(
"Server={0};Username={1};Database={2};Port={3};Password={4};SSLMode=Prefer",
Host,
User,
DBname,
Port,
Password);
using (var conn = new NpgsqlConnection(connString))
{
Console.Out.WriteLine("Opening connection");
conn.Open();
using (var command = new NpgsqlCommand("DROP TABLE IF EXISTS inventory", conn))
{
command.ExecuteNonQuery();
Console.Out.WriteLine("Finished dropping table (if existed)");
}
using (var command = new NpgsqlCommand("CREATE TABLE inventory(id serial PRIMARY KEY, name VARCHAR(50), quantity INTEGER)", conn))
{
command.ExecuteNonQuery();
Console.Out.WriteLine("Finished creating table");
}
using (var command = new NpgsqlCommand("INSERT INTO inventory (name, quantity) VALUES (@n1, @q1), (@n2, @q2), (@n3, @q3)", conn))
{
command.Parameters.AddWithValue("n1", "banana");
command.Parameters.AddWithValue("q1", 150);
command.Parameters.AddWithValue("n2", "orange");
command.Parameters.AddWithValue("q2", 154);
command.Parameters.AddWithValue("n3", "apple");
command.Parameters.AddWithValue("q3", 100);
int nRows = command.ExecuteNonQuery();
Console.Out.WriteLine(String.Format("Number of rows inserted={0}", nRows));
}
}
Console.WriteLine("Press RETURN to exit");
Console.ReadLine();
}
}
}
步驟 2:讀取資料
使用下列程式碼搭配 SELECT SQL 陳述式來連線和讀取資料。 程式碼會使用 NpgsqlCommand 類別搭配下列方法:
- Open() 建立 PostgreSQL 的連線。
- CreateCommand() 和 ExecuteReader() 執行資料庫命令。
- Read() 前往結果中的記錄。
- GetInt32() 和 GetString() 剖析記錄中的值。
重要
以建立伺服器和資料庫時所指定的值,取代主機、資料庫名稱、使用者和密碼參數。
using System;
using Npgsql;
namespace Driver
{
public class AzurePostgresRead
{
// Obtain connection string information from the portal
//
private static string Host = "mydemoserver.postgres.database.azure.com";
private static string User = "mylogin";
private static string DBname = "postgres";
private static string Password = "<server_admin_password>";
private static string Port = "5432";
static void Main(string[] args)
{
// Build connection string using parameters from portal
//
string connString =
String.Format(
"Server={0}; User Id={1}; Database={2}; Port={3}; Password={4};SSLMode=Prefer",
Host,
User,
DBname,
Port,
Password);
using (var conn = new NpgsqlConnection(connString))
{
Console.Out.WriteLine("Opening connection");
conn.Open();
using (var command = new NpgsqlCommand("SELECT * FROM inventory", conn))
{
var reader = command.ExecuteReader();
while (reader.Read())
{
Console.WriteLine(
string.Format(
"Reading from table=({0}, {1}, {2})",
reader.GetInt32(0).ToString(),
reader.GetString(1),
reader.GetInt32(2).ToString()
)
);
}
reader.Close();
}
}
Console.WriteLine("Press RETURN to exit");
Console.ReadLine();
}
}
}
步驟 3:更新資料
使用下列程式碼搭配 UPDATE SQL 陳述式來連線和更新資料。 程式碼會使用 NpgsqlCommand 類別搭配下列方法:
- Open() 建立與適用於 PostgreSQL 的 Azure 資料庫彈性伺服器的連線。
- CreateCommand() 設定 CommandText 屬性。
- ExecuteNonQuery() 方法執行資料庫命令。
重要
以建立伺服器和資料庫時所指定的值,取代主機、資料庫名稱、使用者和密碼參數。
using System;
using Npgsql;
namespace Driver
{
public class AzurePostgresUpdate
{
// Obtain connection string information from the portal
//
private static string Host = "mydemoserver.postgres.database.azure.com";
private static string User = "mylogin";
private static string DBname = "postgres";
private static string Password = "<server_admin_password>";
private static string Port = "5432";
static void Main(string[] args)
{
// Build connection string using parameters from portal
//
string connString =
String.Format(
"Server={0}; User Id={1}; Database={2}; Port={3}; Password={4};SSLMode=Prefer",
Host,
User,
DBname,
Port,
Password);
using (var conn = new NpgsqlConnection(connString))
{
Console.Out.WriteLine("Opening connection");
conn.Open();
using (var command = new NpgsqlCommand("UPDATE inventory SET quantity = @q WHERE name = @n", conn))
{
command.Parameters.AddWithValue("n", "banana");
command.Parameters.AddWithValue("q", 200);
int nRows = command.ExecuteNonQuery();
Console.Out.WriteLine(String.Format("Number of rows updated={0}", nRows));
}
}
Console.WriteLine("Press RETURN to exit");
Console.ReadLine();
}
}
}
步驟 4:刪除資料
使用下列程式碼搭配 DELETE SQL 陳述式來連線和刪除資料。
此代碼使用 NpgsqlCommand 類別搭配 Open() 方法來對適用於 PostgreSQL 的 Azure 資料庫建立連線。 然後,程式碼會使用 CreateCommand() 方法,設定 CommandText 屬性,並呼叫 ExecuteNonQuery() 方法來執行資料庫命令。
重要
以建立伺服器和資料庫時所指定的值,取代主機、資料庫名稱、使用者和密碼參數。
using System;
using Npgsql;
namespace Driver
{
public class AzurePostgresDelete
{
// Obtain connection string information from the portal
//
private static string Host = "mydemoserver.postgres.database.azure.com";
private static string User = "mylogin@mydemoserver";
private static string DBname = "postgres";
private static string Password = "<server_admin_password>";
private static string Port = "5432";
static void Main(string[] args)
{
// Build connection string using parameters from portal
//
string connString =
String.Format(
"Server={0}; User Id={1}; Database={2}; Port={3}; Password={4};SSLMode=Prefer",
Host,
User,
DBname,
Port,
Password);
using (var conn = new NpgsqlConnection(connString))
{
Console.Out.WriteLine("Opening connection");
conn.Open();
using (var command = new NpgsqlCommand("DELETE FROM inventory WHERE name = @n", conn))
{
command.Parameters.AddWithValue("n", "orange");
int nRows = command.ExecuteNonQuery();
Console.Out.WriteLine(String.Format("Number of rows deleted={0}", nRows));
}
}
Console.WriteLine("Press RETURN to exit");
Console.ReadLine();
}
}
}
清除資源
若要清除在此快速入門期間使用的所有資源,請使用下列命令刪除資源群組:
az group delete \
--name $AZ_RESOURCE_GROUP \
--yes