Rust 連接 SQLite 數據庫

使用 Rust 語言連接操作 SQLite 數據庫,我使用 rusqlite 這個 crate。

看例子:

首先,使用 cargo 創建一個 Rust 項目,然後添加依賴 rusqlite:

來到 main.rs,其餘所有的代碼都寫在這裏。

首先引入 rusqlite 相關的類型,並建立一個 Person struct:

Person 有三個字段,id、name 和 data,其實本例中,我們只會用到前兩個字段。

下面,編寫一個用來創建數據庫和 person 表的函數:

該函數會創建名爲 data.db 的數據庫文件(如果不存在的話),然後打開一個數據庫 lian jie,並刪除 person 表(如果存在的話),然後再建立一個 person 表,最後將 Connection 返回。

接下來,我們再創建一個 insert_data 函數,它用來插入兩條數據,它使用 create_db 函數返回的 Connection 的引用作爲參數:

再創建一個可以從數據庫查詢數據的函數 get_data,它會返回一個 Person 的 Vec:

最後,我們在 main 函數里依次調用這些函數,並把從數據庫讀取的數據進行打印:

運行結果:

留一個問題:代碼中經常出現的 ? 是什麼作用?如果不知道的話,可以先把 ? 去掉試一試。

本文由 Readfog 進行 AMP 轉碼,版權歸原作者所有。
來源https://mp.weixin.qq.com/s/cI2j8W-g7r2E7Nez5Az1WQ