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

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

軟件下載吧

當(dāng)前位置:軟件下載吧 > 技術(shù)開(kāi)發(fā) > 數(shù)據(jù)庫(kù) > Rust?連接?PostgreSQL?數(shù)據(jù)庫(kù)的詳細(xì)過(guò)程

Rust?連接?PostgreSQL?數(shù)據(jù)庫(kù)的詳細(xì)過(guò)程

時(shí)間:2024-02-03 17:42作者:下載吧人氣:37

pgxr 是一個(gè) Rust 的 crate 庫(kù),可以實(shí)現(xiàn)用 Rust 語(yǔ)言來(lái)編寫(xiě) PostgreSQL 的擴(kuò)展函數(shù)(相當(dāng)于存儲(chǔ)過(guò)程)。

這次,我們使用 postgres 這個(gè) crate 來(lái)連接和操作 PostgreSQL 數(shù)據(jù)庫(kù)。

創(chuàng)建好項(xiàng)目后,在 cargo.toml 里添加 postgres 的依賴(lài):

Rust?連接?PostgreSQL?數(shù)據(jù)庫(kù)的詳細(xì)過(guò)程

首先,導(dǎo)入相關(guān)的類(lèi)型,并創(chuàng)建一個(gè) Person struct:

Rust?連接?PostgreSQL?數(shù)據(jù)庫(kù)的詳細(xì)過(guò)程

再創(chuàng)建 create_db 函數(shù),用來(lái)創(chuàng)建數(shù)據(jù)庫(kù)和表,它返回一個(gè) Result,里面可能是 Client 或錯(cuò)誤:

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

Rust?連接?PostgreSQL?數(shù)據(jù)庫(kù)的詳細(xì)過(guò)程

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

一個(gè)相對(duì)完整的數(shù)據(jù)庫(kù)連接字符串 URL 格式是:

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

Client::connect() 函數(shù)的第二個(gè)參數(shù)用的是 NoTls,為了簡(jiǎn)單起見(jiàn),這里我們不使用 TLS。

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

最后返回 Client。

接下來(lái),創(chuàng)建 insert_data 函數(shù),來(lái)插入一些數(shù)據(jù):

Rust?連接?PostgreSQL?數(shù)據(jù)庫(kù)的詳細(xì)過(guò)程

注意該函數(shù)的參數(shù) Client 必須是 mut 的。

再創(chuàng)建一個(gè)查詢(xún)數(shù)據(jù)的函數(shù):

Rust?連接?PostgreSQL?數(shù)據(jù)庫(kù)的詳細(xì)過(guò)程

這里,我們直接對(duì) Client 的 query 方法返回的結(jié)果進(jìn)行遍歷,最后方法返回一個(gè) Vec。

最后,在 main 函數(shù)里依次調(diào)用這些函數(shù),并把查詢(xún)結(jié)果打印出來(lái):

Rust?連接?PostgreSQL?數(shù)據(jù)庫(kù)的詳細(xì)過(guò)程

結(jié)果如下:

Rust?連接?PostgreSQL?數(shù)據(jù)庫(kù)的詳細(xì)過(guò)程

全部代碼如下:

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);

標(biāo)簽MySQL,技術(shù)文檔,數(shù)據(jù)庫(kù),PostgreSQL

相關(guān)下載

查看所有評(píng)論+

網(wǎng)友評(píng)論

網(wǎng)友
您的評(píng)論需要經(jīng)過(guò)審核才能顯示

熱門(mén)閱覽

最新排行

公眾號(hào)

主站蜘蛛池模板: 国产午夜精品一区二区 | 扒开双腿猛进入爽爽在线观看 | 免费一级欧美片在线观看 | 日韩一级片免费 | 一区二区三区精品国产 | 亚洲精品国产一区二区图片欧美 | 日韩欧美毛片免费看播放 | 91情侣高清精品国产 | 国产黄色一级毛片 | 免费国产综合视频在线看 | 日本欧美在线视频 | 日韩欧美一区二区久久 | 成年女人色毛片免费 | 国产特黄一级毛片特黄 | 国产成人禁片免费观看 | 亚洲国产欧美一区二区欧美 | 亚洲精品区一区二区三区四 | 国内自拍小视频 | 亚洲精品国产啊女成拍色拍 | 欧美日韩中文一区二区三区 | 国产成人福利夜色影视 | 久久久久成人精品一区二区 | 国内精品久久久久影院网站 | 亚洲成a v人片在线观看 | 国产在线成人一区二区 | 日韩中文字幕精品一区在线 | 欧美人在线一区二区三区 | gdcm01果冻传媒| 午夜欧美日韩在线视频播放 | 曰本女同互慰高清在线观看 | 国产成人高清亚洲一区久久 | 欧美操操操操 | 国产免费人成在线看视频 | 香蕉超级碰碰碰97视频在线观看 | 欧美日韩精品一区二区免费看 | 国产毛片一级国语版 | 日本视频免费在线播放 | 最近手机中文在线视频 | 玖玖精品视频在线 | 91欧美一区二区三区综合在线 | 看一级毛片国产一级毛片 |