網站首頁 編程語言 正文
pgxr 是一個 Rust 的 crate 庫,可以實現用 Rust 語言來編寫 PostgreSQL 的擴展函數(相當于存儲過程)。
這次,我們使用 postgres 這個 crate 來連接和操作 PostgreSQL 數據庫。
創建好項目后,在 cargo.toml 里添加 postgres 的依賴:
首先,導入相關的類型,并創建一個 Person struct:
再創建 create_db 函數,用來創建數據庫和表,它返回一個 Result,里面可能是 Client 或錯誤:
注意,Client::connect() 函數所接受的連接字符串可以是兩種形式的:
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 函數,來插入一些數據:
注意該函數的參數 Client 必須是 mut 的。
再創建一個查詢數據的函數:
這里,我們直接對 Client 的 query 方法返回的結果進行遍歷,最后方法返回一個 Vec。
最后,在 main 函數里依次調用這些函數,并把查詢結果打印出來:
結果如下:
全部代碼如下:
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);
原文鏈接:https://www.cnblogs.com/yangxu-pro/p/15831849.html
相關推薦
- 2022-08-23 .net中的Span<T>類和Memory<T>類介紹_基礎應用
- 2024-03-19 關于maven打包時,沒有將依賴包打進來的問題
- 2023-01-08 react?頁面加載完成后自動執行標簽的點擊事件的兩種操作方法_React
- 2023-01-28 GoLang分布式鎖與snowflake雪花算法_Golang
- 2023-11-15 Python pip指定安裝鏡像源;pip安裝如何指定和更改鏡像源?
- 2022-10-14 基于docker容器的gitlab遷移與數據恢復
- 2022-06-21 C#實現XML文件與DataTable、Dataset互轉_C#教程
- 2022-09-25 Iterable,Collection和List的常見方法簽名及含義
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支