Rust?連接?PostgreSQL?數(shù)據(jù)庫的詳細(xì)過程
pgxr 是一個(gè) Rust 的 crate 庫,可以實(shí)現(xiàn)用 Rust 語言來編寫 PostgreSQL 的擴(kuò)展函數(shù)(相當(dāng)于存儲(chǔ)過程)。
這次,我們使用 postgres 這個(gè) crate 來連接和操作 PostgreSQL 數(shù)據(jù)庫。
創(chuàng)建好項(xiàng)目后,在 cargo.toml 里添加 postgres 的依賴:
首先,導(dǎo)入相關(guān)的類型,并創(chuàng)建一個(gè) Person struct:
再創(chuàng)建 create_db 函數(shù),用來創(chuàng)建數(shù)據(jù)庫和表,它返回一個(gè) Result,里面可能是 Client 或錯(cuò)誤:
注意,Client::connect() 函數(shù)所接受的連接字符串可以是兩種形式的:
Key-Value 形式。例如:Client::connect("host=localhost user=postgres", NoTls)?; 具體的 key 需要查閱官方文檔。URL 形式。本例中使用的是 URL 形式。
一個(gè)相對(duì)完整的數(shù)據(jù)庫連接字符串 URL 格式是:
postgres://username[:password]@host[:port][/database],其中 password、port、database 都是可選的。所以上面代碼中做了相應(yīng)的判斷處理。
Client::connect() 函數(shù)的第二個(gè)參數(shù)用的是 NoTls,為了簡(jiǎn)單起見,這里我們不使用 TLS。
第 30、32 行,使用 Client 的 execute 方法先刪除數(shù)據(jù)表(如果存在的話),然后再創(chuàng)建 person 表。
最后返回 Client。
接下來,創(chuàng)建 insert_data 函數(shù),來插入一些數(shù)據(jù):
注意該函數(shù)的參數(shù) Client 必須是 mut 的。
再創(chuàng)建一個(gè)查詢數(shù)據(jù)的函數(shù):
這里,我們直接對(duì) Client 的 query 方法返回的結(jié)果進(jìn)行遍歷,最后方法返回一個(gè) Vec。
最后,在 main 函數(shù)里依次調(diào)用這些函數(shù),并把查詢結(jié)果打印出來:
結(jié)果如下:
全部代碼如下:
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);
到此這篇關(guān)于Rust連接PostgreSQL數(shù)據(jù)庫的文章就介紹到這了,更多相關(guān)RustPostgreSQL數(shù)據(jù)庫內(nèi)容請(qǐng)搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。