This is a driver for LINQPad to add support for PostgreSQL databases. This driver uses LINQ to DB to execute the LINQ queries and Npgsql for the database access. In addition Dapper is used for a more convenient database access during the model creation.
This driver has been tested with PostgreSQL 9.4.4 but should work with all versions supported by LINQ to DB v1.0.7.4 and Npgsql v3.0.7. It can be used with LINQPad versions 4 and 5.
- Download the
.lpx
file of the latest release from the releases tab (e.g.LINQPad.PostgreSQL.Driver.0.1.2.lpx
). - Run LINQPad and click Add connection.
- Click View more drivers.
- Click Browse and select the
.lpx
file. The driver has now been installed. - The driver (PostgreSQL (LINQ to DB)) should now show up in the Add connection dialog.
- Click Add connection, select the driver and click Next.
- Provide the connection info by either specifying the server (e.g.
localhost:5432
) and database (with optional username and password) or by specifying a Npgsql connection string manually. If you do not specify a port explicitly the default port5432
is used. - Create the connection by clicking the Save button.
Unfortunately, editing data directly in the results grid is not supported for third-party drivers. You can, however, use the LINQ to DB DataConnection
to modify your data. The DataConnection
can be accessed using the this
keyword in your query. In the following some samples to insert, update and delete records are provided. You can get more detailed information on the LINQ to DB website.
If you want to provide an ID yourself:
var user = new User();
user.Id = 42;
user.Name = "John Doe";
user.Emailaddress = "[email protected]";
this.Insert(user);
If the ID is generated by the database:
var user = new User();
user.Name = "John Doe";
user.Emailaddress = "[email protected]";
var userId = this.InsertWithIdentity(user);
If you have an instance of the object you want to update:
var user = Users.Single(u => u.Id == 42);
user.Emailaddress = "[email protected]";
this.Update(user);
If you want to update all records matching certain criteria:
Users.Where(u => u.Id == 42)
.Set(u => u.Emailaddress, "[email protected]")
.Update();
If you have an instance of the object you want to delete:
var user = Users.Single(u => u.Id == 42);
this.Delete(user);
If you want to delete all records matching certain criteria:
Users.Delete(u => u.Id == 42);