Crates.io | async-postgres |
lib.rs | async-postgres |
version | 0.5.1 |
source | src |
created_at | 2020-04-07 20:19:42.783172 |
updated_at | 2020-07-20 07:55:43.594805 |
description | A runtime-independent, asynchronous PostgreSQL client. |
homepage | |
repository | https://github.com/Hexilee/async-postgres |
max_upload_size | |
id | 227450 |
size | 31,516 |
This crate is a wrapper of tokio-postgres.
Runtime-independent, can be used on any async runtime.
Almost the same with tokio-postgres.
use async_postgres::connect;
use std::error::Error;
use async_std::task::spawn;
async fn play() -> Result<(), Box<dyn Error>> {
let url = "host=localhost user=postgres";
let (client, conn) = connect(url.parse()?).await?;
spawn(conn);
let row = client.query_one("SELECT * FROM user WHERE id=$1", &[&0]).await?;
let value: &str = row.get(0);
println!("value: {}", value);
Ok(())
}
use async_postgres::connect_tls;
use native_tls::{Certificate, TlsConnector};
use postgres_native_tls::MakeTlsConnector;
use std::fs;
use std::error::Error;
use async_std::task::spawn;
async fn play() -> Result<(), Box<dyn Error>> {
let cert = fs::read("database_cert.pem")?;
let cert = Certificate::from_pem(&cert)?;
let connector = TlsConnector::builder()
.add_root_certificate(cert)
.build()?;
let connector = MakeTlsConnector::new(connector);
let url = "host=localhost user=postgres sslmode=require";
let (client, conn) = connect_tls(url.parse()?, connector).await?;
spawn(conn);
let row = client.query_one("SELECT * FROM user WHERE id=$1", &[&0]).await?;
let value: &str = row.get(0);
println!("value: {}", value);
Ok(())
}
Almost the same with tokio-postgres, you can see a live benchmark here.
Running tests needs a postgres server and environment variables:
TCP_URL="postgresql:///<db>?host=<tcp host>&port=<port>&user=<user>&password=<passwd>"
UDS_URL="postgresql:///<db>?host=<postgres uds dir>&port=<port>&user=<user>&password=<passwd>"