Back to Yugabyte Db

PostgreSQL Npgsql Driver

docs/content/stable/develop/drivers-orms/csharp/postgres-npgsql-reference.md

2026.1.0.0-b258.3 KB
Original Source
<ul class="nav nav-tabs-alt nav-tabs-yb"> <li > <a href="../yb-npgsql-reference/" class="nav-link"> <i class="icon-postgres" aria-hidden="true"></i> YugabyteDB Npgsql Smart Driver </a> </li> <li > <a href="../postgres-npgsql-reference/" class="nav-link active"> <i class="icon-postgres" aria-hidden="true"></i> PostgreSQL Npgsql Driver </a> </li> </ul>

Npgsql is an open source ADO.NET Data Provider for PostgreSQL; it allows programs written in C#, Visual Basic, and F# to access the YugabyteDB server. Npgsql is based on libpq and supports the SCRAM-SHA-256 authentication method.

For details on Npgsql, refer to the Npgsql documentation.

For building a sample C# application with Npgsql, see Connect an application.

Download the driver dependency

If you are using Visual Studio IDE, add the Npgsql package to your project as follows:

  1. Right-click Dependencies and choose Manage Nuget Packages
  2. Search for Npgsql and click Add Package

To add the Npgsql package to your project when not using an IDE, use the following dotnet command:

csharp
dotnet add package Npgsql

or any of the other methods mentioned on the nuget page for Npgsql.

Fundamentals

Learn how to perform common tasks required for C# application development using the Npgsql driver.

Connect to YugabyteDB database

After setting up the dependencies, implement the C# client application that uses the Npgsql driver to connect to your YugabyteDB cluster and run a query on the sample data.

Import Npgsql and use the NpgsqlConnection class to create the connection object to perform DDLs and DMLs against the database.

The following table describes the connection parameters for connecting to the YugabyteDB database.

ParametersDescriptionDefault
HostHost name of the YugabyteDB instancelocalhost
PortListen port for YSQL5433
DatabaseDatabase nameyugabyte
UsernameUser connecting to the databaseyugabyte
PasswordPassword for the useryugabyte

The following is a basic example connection string for connecting to YugabyteDB.

csharp
var connStringBuilder = "Host=localhost;Port=5433;Database=yugabyte;Username=yugabyte;Password=password"
NpgsqlConnection conn = new NpgsqlConnection(connStringBuilder);

{{< warning title="Warning" >}}

On every new connection, the Npgsql driver also makes extra system table queries to map types, which adds significant overhead. It is recommended that you turn this behavior off to significantly reduce connection open execution time.

Set the following option in your connection string builder:

csharp
connStringBuilder.ServerCompatibilityMode = ServerCompatibilityMode.NoTypeLoading;

Alternatively, you can add the following to your connection string:

csharp
Server Compatibility Mode=NoTypeLoading;

{{< /warning >}}

Create table

Tables can be created in YugabyteDB by passing the CREATE TABLE DDL statement to the NpgsqlCommand class and getting a command object, then calling the ExecuteNonQuery() method using this command object.

sql
CREATE TABLE employee (id int PRIMARY KEY, name varchar, age int, language varchar)
csharp
conn.Open();
NpgsqlCommand empCreateCmd = new NpgsqlCommand("CREATE TABLE employee (id int PRIMARY KEY, name varchar, age int, language varchar);", conn);
empCreateCmd.ExecuteNonQuery();

Read and write data

Insert data

To write data into YugabyteDB, execute the INSERT statement using the NpgsqlCommand class, get a command object, and then call the ExecuteNonQuery() method using this command object.

sql
INSERT INTO employee (id, name, age, language) VALUES (1, 'John', 35, 'CSharp');
csharp
NpgsqlCommand empInsertCmd = new NpgsqlCommand("INSERT INTO employee (id, name, age, language) VALUES (1, 'John', 35, 'CSharp');", conn);
int numRows = empInsertCmd.ExecuteNonQuery();

Query data

To query data from YugabyteDB tables, execute the SELECT statement using the NpgsqlCommand class, get a command object, and then call the ExecuteReader() function using the object. Loop through the reader to get the list of returned rows.

sql
SELECT * from employee where id=1;
csharp
NpgsqlCommand empPrepCmd = new NpgsqlCommand("SELECT name, age, language FROM employee WHERE id = @EmployeeId", conn);
empPrepCmd.Parameters.Add("@EmployeeId", NpgsqlTypes.NpgsqlDbType.Integer);

empPrepCmd.Parameters["@EmployeeId"].Value = 1;
NpgsqlDataReader reader = empPrepCmd.ExecuteReader();

Console.WriteLine("Query returned:\nName\tAge\tLanguage");
while (reader.Read())
{
    Console.WriteLine("{0}\t{1}\t{2}", reader.GetString(0), reader.GetInt32(1), reader.GetString(2));
}

Configure SSL/TLS

The following table describes the additional parameters the .NET Npgsql driver requires as part of the connection string when using SSL.

Npgsql ParameterDescription
SslModeSSL Mode
RootCertificatePath to the root certificate on your computer
TrustServerCertificateFor use with the Require SSL mode

Npgsql supports SSL modes in different ways depending on the driver version, as shown in the following table.

SSL modeVersions before 6.0Version 6.0 or later
DisableSupported (default)Supported
AllowNot SupportedSupported
PreferSupportedSupported (default)
RequireSupported
For self-signed certificates, set TrustServerCertificate to trueSupported
Set TrustServerCertificate to true
VerifyCANot Supported - use RequireSupported
VerifyFullNot Supported - use RequireSupported

The .NET Npgsql driver validates certificates differently from other PostgreSQL drivers as follows:

  • Prior to version 6.0, when you specify SSL mode Require, you also need to specify RootCertificate, and the driver verifies the certificate by default (like the verify CA or verify full modes on other drivers), and fails for self-signed certificates.

    To use self-signed certificates, specify TrustServerCertificate=true, which bypasses walking the certificate chain to validate trust and hence works like other drivers' require mode. In this case, you don't need to specify the RootCertificate.

  • For version 6.0 and later, the Require SSL mode requires explicitly setting the TrustServerCertificate field to true.

The following example shows how to build a connection string for connecting to a YugabyteDB cluster using the Require SSL mode.

csharp
var connStringBuilder = new NpgsqlConnectionStringBuilder();
    connStringBuilder.Host = "22420e3a-768b-43da-8dcb-xxxxxx.aws.yugabyte.cloud";
    connStringBuilder.Port = 5433;
    connStringBuilder.SslMode = SslMode.Require;
    connStringBuilder.Username = "admin";
    connStringBuilder.Password = "xxxxxx";
    connStringBuilder.Database = "yugabyte";
    connStringBuilder.TrustServerCertificate = true;
    CRUD(connStringBuilder.ConnectionString);

The following example shows how to build a connection string for connecting to a YugabyteDB cluster using the VerifyCA and VerifyFull SSL modes.

csharp
var connStringBuilder = new NpgsqlConnectionStringBuilder();
    connStringBuilder.Host = "22420e3a-768b-43da-8dcb-xxxxxx.aws.yugabyte.cloud";
    connStringBuilder.Port = 5433;
    connStringBuilder.SslMode = SslMode.VerifyCA;
    //or connStringBuilder.SslMode = SslMode.VerifyFull;
    connStringBuilder.RootCertificate = "/root.crt"; //Provide full path to your root CA.
    connStringBuilder.Username = "admin";
    connStringBuilder.Password = "xxxxxx";
    connStringBuilder.Database = "yugabyte";
    CRUD(connStringBuilder.ConnectionString);

For more information on TLS/SSL support, see Security and Encryption in the Npgsql documentation.

Compatibility matrix

Driver VersionYugabyteDB VersionSupport
6.0.32.11 (preview)full
6.0.32.8 (stable)full
6.0.32.6full