日韩小视频-日韩久久一区二区三区-日韩久久一级毛片-日韩久久久精品中文字幕-国产精品亚洲精品影院-国产精品亚洲欧美云霸高清

下載吧 - 綠色安全的游戲和軟件下載中心

軟件下載吧

當前位置:軟件下載吧 > 技術開發 > 數據庫 > Rust?連接?PostgreSQL?數據庫的詳細過程

Rust?連接?PostgreSQL?數據庫的詳細過程

時間:2024-02-03 17:42作者:下載吧人氣:23

pgxr 是一個 Rust 的 crate 庫,可以實現用 Rust 語言來編寫 PostgreSQL 的擴展函數(相當于存儲過程)。

這次,我們使用 postgres 這個 crate 來連接和操作 PostgreSQL 數據庫。

創建好項目后,在 cargo.toml 里添加 postgres 的依賴:

Rust?連接?PostgreSQL?數據庫的詳細過程

首先,導入相關的類型,并創建一個 Person struct:

Rust?連接?PostgreSQL?數據庫的詳細過程

再創建 create_db 函數,用來創建數據庫和表,它返回一個 Result,里面可能是 Client 或錯誤:

注意,Client::connect() 函數所接受的連接字符串可以是兩種形式的:

Rust?連接?PostgreSQL?數據庫的詳細過程

Key-Value 形式。例如:Client::connect("host=localhost user=postgres", NoTls)?; 具體的 key 需要查閱官方文檔。URL 形式。本例中使用的是 URL 形式。

一個相對完整的數據庫連接字符串 URL 格式是:

postgres://username[:password]@host[:port][/database],其中 password、port、database 都是可選的。所以上面代碼中做了相應的判斷處理。

Client::connect() 函數的第二個參數用的是 NoTls,為了簡單起見,這里我們不使用 TLS。

第 30、32 行,使用 Client 的 execute 方法先刪除數據表(如果存在的話),然后再創建 person 表。

最后返回 Client。

接下來,創建 insert_data 函數,來插入一些數據:

Rust?連接?PostgreSQL?數據庫的詳細過程

注意該函數的參數 Client 必須是 mut 的。

再創建一個查詢數據的函數:

Rust?連接?PostgreSQL?數據庫的詳細過程

這里,我們直接對 Client 的 query 方法返回的結果進行遍歷,最后方法返回一個 Vec。

最后,在 main 函數里依次調用這些函數,并把查詢結果打印出來:

Rust?連接?PostgreSQL?數據庫的詳細過程

結果如下:

Rust?連接?PostgreSQL?數據庫的詳細過程

全部代碼如下:

use postgres::{error::Error, Client, NoTls};

#[derive(Debug)]
struct Person {
id: i32,
name: String,
data: Option<Vec<u8>>,
}
fn create_db() -> Result<Client, Error> {
let username = “postgres”;
let password = “postgres”;
let host = “localhost”;
let port = “5432”;
let database = “rust2021”;
let conn_str = &format!(
“postgres://{}{}{}@{}{}{}{}{}”,
username,
if password.is_empty() { “” } else { “:” },
password,
host,
if port.is_empty() { “” } else { “:” },
port,
if database.is_empty() { “” } else { “/” },
database
);
let mut client = Client::connect(conn_str, NoTls)?;
let _ = client.execute(“DROP TABLE person”, &[]);
client.execute(
“CREATE TABLE person (
id SERIAL PRIMARY KEY,
name TEXT NOT NULL,
data BYTEA
)”,
&[],
)?;
Ok(client)
fn insert_data(client: &mut Client) -> Result<(), Error> {
let p1 = Person {
id: 1,
name: “Dave”.to_string(),
data: None,
};
let p2 = Person {
id: 2,
name: “Nick”.to_string(),
“INSERT INTO person (id, name, data)
VALUES ($1, $2, $3),
($4, $5, $6)”,
&[&p1.id, &p1.name, &p1.data, &p2.id, &p2.name, &p2.data],
Ok(())
fn get_data(client: &mut Client) -> Result<Vec<Person>, Error> {
let mut persons = Vec::new();
for row in client.query(“SELECT id, name, data FROM person”, &[])? {
persons.push(Person {
id: row.get(0),
name: row.get(1),
data: row.get(2),
});
}
Ok(persons)
fn main() -> Result<(), Error> {
let mut client = create_db()?;
insert_data(&mut client)?;
let persons = get_data(&mut client)?;
for p in persons {
println!(“Person: {:?}”, p);

標簽MySQL,技術文檔,數據庫,PostgreSQL

相關下載

查看所有評論+

網友評論

網友
您的評論需要經過審核才能顯示

熱門閱覽

最新排行

公眾號

主站蜘蛛池模板: 日韩美香港a一级毛片 | 日韩欧美一区二区不卡看片 | 国产免费一级片 | 国产专区中文字幕 | 亚洲网美女 | 大量真实偷拍情侣视频野战 | 欧美俄罗斯一级毛片激情 | 日韩中文在线 | 中文字幕亚洲一区 | 视频一区 在线 | 午夜精品同性女女 | 男女很舒服爽视频免费 | 亚洲欧美一区二区三区在线 | 午夜在线观看视频免费 成人 | 国产欧美日韩综合精品一区二区 | 美女视频永久黄网站免费观看韩国 | 成网站在线观看人免费 | 国产成人a在一区线观看高清 | 永久精品免费影院在线观看网站 | 一区二区国产精品 | 午夜精品视频 | 欧美一级毛片欧美毛片视频 | 日韩成人免费一级毛片 | 成人黄色一级视频 | 久久精品午夜视频 | 成人亚洲国产精品久久 | 亚洲超大尺度激情啪啪人体 | 亚洲毛片在线 | 日韩欧一级毛片在线播无遮挡 | 国产v综合v亚洲欧美大另类 | 国产精品九九九久久九九 | 国产午夜精品不卡视频 | 99精品欧美一区二区三区美图 | 日韩欧美a级高清毛片 | 真人毛片免费全部播放完整 | 成人18视频在线观看 | 国内自拍在线 | 一区二区三区视频观看 | 在线观看国产日韩 | 亚洲第四页| 美女黄网站人色视频免费国产 |