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

          軟件下載吧

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

          最后返回 Client。

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

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

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

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

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

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

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

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

          結(jié)果如下:

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

          全部代碼如下:

          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ù)庫,PostgreSQL

          相關(guān)下載

          查看所有評論+

          網(wǎng)友評論

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

          熱門閱覽

          最新排行

          公眾號

          主站蜘蛛池模板: 人妻无码一区二区三区免费| 无码精品久久一区二区三区 | 亚洲蜜芽在线精品一区| 亚洲AV永久无码精品一区二区国产 | 无码一区二区三区中文字幕| 亚洲熟女少妇一区二区| 福利在线一区二区| 国产日本亚洲一区二区三区| 美女毛片一区二区三区四区| 国产精品视频一区二区三区经| 精品无码国产AV一区二区三区| 精品国产一区二区三区久久影院| 亚洲av区一区二区三| 国产综合无码一区二区三区| 精品视频一区二区三区在线观看| 亚洲国产成人久久一区二区三区| 亚洲日本中文字幕一区二区三区| 精品无码AV一区二区三区不卡| 国产精品亚洲一区二区三区| 精品视频一区二区三区免费 | 一区二区三区在线视频播放| 亚洲制服中文字幕第一区| 国产一区二区三区免费看| 日韩精品无码一区二区视频 | 色精品一区二区三区| 无码一区二区三区| 视频一区视频二区日韩专区| 大伊香蕉精品一区视频在线| 精品不卡一区二区| 中文字幕国产一区| 日韩在线观看一区二区三区| 亚洲国产精品乱码一区二区| 亚洲一区无码精品色| 免费无码一区二区| 无码国产精品一区二区免费式影视 | 无码中文字幕乱码一区| 亚洲一区二区三区夜色| 国产av一区二区三区日韩| 久久精品无码一区二区app| 中文字幕日韩欧美一区二区三区 | 中文字幕在线不卡一区二区|