rust調用SQLite實例

rusqlite庫介紹

Rusqlite是一個用Rust編寫的SQLite庫,它提供了對SQLite數據庫的操作功能。Rusqlite的設計目標是提供一個簡潔易用的API,以便于Rust程序員能夠方便地訪問和操作SQLite數據庫。

Rusqlite的主要特點包括:

  • 遵循Rust的類型系統和所有權模型,提供安全的API設計;
  • 支持異步和同步兩種模式,以適應不同的應用場景;
  • 提供豐富的功能,如數據庫連接管理、事務處理、查詢執行、數據綁定和結果集處理等;
  • 支持自動重連機制,能夠在網絡中斷或其他異常情況下自動恢復連接;
  • 支持多種數據類型的轉換,包括字符串、整數、浮點數、日期時間等;
  • 提供詳細的文檔和示例代碼,便于開發者快速上手和使用。

Rusqlite廣泛應用于各種需要輕量級數據庫支持的Rust項目中,例如Web應用程序、命令行工具、嵌入式設備等。此外,Rusqlite也經常與其他Rust庫配合使用,以實現更復雜的功能和需求

下面是庫使用案例

目錄結構

cargo.toml配置文件

[package]
name = "mySQLite"
version = "0.1.0"
edition = "2021"[dependencies]
rusqlite = { version = "0.31.0", features = ["bundled"] }
[[example]]
name = "createSQLiteDatabase"
path = "examples/SQL/createSQLiteDatabase.rs"
doc-scrape-examples = true[package.metadata.example.createSQLiteDatabase]
name = "Create SQLite Database"
description = "demonstrates SQLite database create"
category = "SQL Rendering"
wasm = true

執行文件 createSQLiteDatabase.rs 內容

增刪改查執行案例

use rusqlite::{Connection, Result};
use std::fs;
#[derive(Debug)]
struct Person {id: i32,name: String,data: Option<Vec<u8>>,
}pub fn main() -> Result<()> {let conn = establish_connection();// let conn = Connection::open_in_memory()?;// let conn = Connection::open("cats.db")?;conn.execute("CREATE TABLE  person   (id    INTEGER PRIMARY KEY,name  TEXT NOT NULL,data  BLOB) ",(), // empty list of parameters.)?;let mut me = Person {id: 0,name: "Steven".to_string(),data: None,};conn.execute("INSERT INTO person (name, data) VALUES (?1, ?2)",(&me.name, &me.data),)?;let mut stmt = conn.prepare("SELECT id, name, data FROM person")?;let person_iter = stmt.query_map([], |row| {Ok(Person {id: row.get(0)?,name: row.get(1)?,data: row.get(2)?,})})?;for person in person_iter {println!("Found person {:?}", person.unwrap());}/*// 刪除SQLite數據表let _res = conn.execute("DROP TABLE IF EXISTS person;", []);println!("{:?}", _res);*//*
// 刪除數據
// 準備刪除語句let mut statement = conn.prepare("DELETE FROM person")?;// 執行刪除操作statement.execute(())?;*//*// 刪除數據
// 準備刪除語句let mut statement = conn.prepare("DELETE FROM person WHERE id =1")?;// 執行刪除操作statement.execute(())?;*/// 準備一個SQL更新語句//更新數據let p = Person{id: 1,name: "Server".to_string(),data: None,};let mut update_stmt =conn.prepare("UPDATE person SET name = ?1 WHERE id = ?2").unwrap();update_stmt.execute((p.name,p.id)).unwrap();println!("{:?}", update_stmt);/*let result = conn.execute("UPDATE person SET name = ?1 WHERE id = ?2",( p.name, p.id),)?;println!("{:?}", result);*////刪除SQLite數據庫,庫必須是被關閉狀態才行if fs::metadata("cats.db").is_ok() {// 刪除數據庫文件fs::remove_file("cats.db").expect("刪除數據庫文件失敗");}selectTable(&conn, "NewName");Ok(())
}
//獲取并返回SQL連接
fn establish_connection() -> rusqlite::Connection {// 創建一個內存中的SQLite數據庫連接match rusqlite::Connection::open_in_memory() {Ok(conn) => conn,Err(e) => panic!("Failed to open a connection: {:?}", e),}
}
//接收SQL連接執行
fn selectTable(conn: &rusqlite::Connection, name: &str) ->Result<()>{// let conn = establish_connection();let mut stmt = conn.prepare("SELECT id, name, data FROM person")?;let person_iter = stmt.query_map([], |row| {Ok(Person {id: row.get(0)?,name: row.get(1)?,data: row.get(2)?,})})?;for person in person_iter {println!("Found person {:?}", person.unwrap());}Ok(())
}

代碼執行方式

cargo run --example createSQLiteDatabase

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/11246.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/11246.shtml
英文地址,請注明出處:http://en.pswp.cn/web/11246.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

SQL_hive的連續開窗函數

SQL三種排序&#xff08;開窗&#xff09;第幾名/前幾名/topN 1三種排序&#xff08;開窗&#xff09;第幾名/前幾名/topN思路 4種排序開窗函數 1三種排序&#xff08;開窗&#xff09;第幾名/前幾名/topN 求每個學生成績第二高的科目-排序思路 t2表&#xff1a;對每個學生 的…

基于Python的web漏洞挖掘掃描技術的實現與研究【附源碼,文檔】

博主介紹&#xff1a;?Java老徐、7年大廠程序員經歷。全網粉絲12w、csdn博客專家、掘金/華為云/阿里云/InfoQ等平臺優質作者、專注于Java技術領域和畢業項目實戰? &#x1f345;文末獲取源碼聯系&#x1f345; &#x1f447;&#x1f3fb; 精彩專欄推薦訂閱&#x1f447;&…

Vue3 項目

創建 Vue3 項目的步驟如下&#xff1a; 安裝 Node.js Vue3 需要依賴 Node.js 環境&#xff0c;因此需要先安裝 Node.js。可以從官網下載 Node.js 的安裝包并安裝&#xff0c;也可以使用包管理器安裝&#xff0c;例如在 Ubuntu 上可以使用以下命令安裝&#xff1a; sudo apt-get…

C語言筆記13

字符數組與字符串常量區別 #include <stdio.h> int main() {char str1[] "hello bit.";char str2[] "hello bit.";char *str3 "hello bit.";char *str4 "hello bit.";if(str1 str2)printf("str1 and str2 are same\n…

【生信技能樹】拿到表達矩陣之后,如何使用ggplot2繪圖系統繪制箱線圖?

拿到表達矩陣之后&#xff0c;如何使用ggplot2繪圖系統繪制箱線圖&#xff1f; 目錄 預備知識 繪制箱線圖示例 預備知識 1.pivot_longer函數 pivot_longer 是tidyr包中的一個函數&#xff0c;用于將數據框&#xff08;data frame&#xff09;從寬格式轉換為長格式。在寬格…

一文掌握gRPC

文章目錄 1. gRPC簡介2. Http2.0協議3. 序列化-Protobuf4. gRPC開發實戰環境搭建5. gRPC的四種通信方式&#xff08;重點&#xff09;6. gRPC的代理方式7. SprintBoot整合gRPC 1. gRPC簡介 gRPC是由google開源的高性能的RPC框架。它是由google的Stubby這樣一個內部的RPC框架演…

reactJs動態執行js代碼

參考了這篇文章 js——new Function 一個可以隨時動態執行字符串js代碼的神器 因為一些原因&#xff0c;想要js代碼塊配置在數據庫中返回&#xff0c;例如時間&#xff0c;我需要用到第三方庫 moment。然后動態的得到startDate 和 endDate 配置在數據庫中的startDate值是$mom…

Java日志總結

開發中&#xff0c;日志記錄是不可或缺的一部分&#xff0c;應用日志的記錄主要用于&#xff1a;記錄操作軌跡數據、監控系統運行情況、系統故障定位問題&#xff0c;日志的重要性不言而喻&#xff0c;想要快速定位問題&#xff0c;日志分析是個重要的手段&#xff0c;Java也提…

JAVA 集合(單列集合)

集合框架 1.集合的特點 a.只能存儲引用數據類型的數據 b.長度可變 c.集合中有大量的方法,方便我們操作 2.分類: a.單列集合:一個元素就一個組成部分: list.add(“張三”) b.雙列集合:一個元素有兩部分構成: key 和 value map.put(“濤哥”,“金蓮”) -> key,value叫做鍵值…

Docker各版本的新特性

Docker 作為流行的容器化平臺&#xff0c;會定期發布新版本以引入新特性、改進和修復。根據提供的搜索結果&#xff0c;以下是一些 Docker 版本及其新特性的概覽&#xff1a; Docker Desktop v4.12 Containerd 的集成&#xff1a;更深入集成 containerd 以管理容器生命周期&a…

鎖和MVCC如何實現mysql的隔離級別

概述 MVCC解決讀的隔離性&#xff0c;加鎖解決寫的隔離性。 讀未提交 讀未提交&#xff0c;更新數據大概率使用的是獨享鎖吧。 讀已提交 在 Read Committed&#xff08;讀已提交&#xff09;隔離級別下&#xff0c;每次執行讀操作時都會生成一個新的 read view。這是因為在讀…

英譯漢早操練-(二十)

hello大家好&#xff0c;這篇跟隨十九&#xff0c;繼續真題學習。如果想看全部請返回到第十九篇。 英譯漢早操練-&#xff08;十九&#xff09;-CSDN博客 The political upheaval in Libya and elsewhere in North Africa has opened the way for thousands of new migrants to…

【C++學習第15天】STL

一、種類 vector&#xff1a;變長數組&#xff0c;倍增的思想。給數組申請空間所耗費的時間取決于申請次數&#xff0c;而不是申請空間的大小&#xff0c;即a[1]和a[10000]兩個數組的申請時間是基本一致的。pair<int, string>&#xff1a;存儲一個二元組&#xff0c;前后…

AI 圖像生成-環境配置

一、python環境安裝 Windows安裝Python&#xff08;圖解&#xff09; 二、CUDA安裝 CUDA安裝教程&#xff08;超詳細&#xff09;-CSDN博客 三、Git安裝 git安裝教程&#xff08;詳細版本&#xff09;-CSDN博客 四、啟動器安裝 這里安裝的是秋葉aaaki的安裝包 【AI繪畫…

【GlobalMapper精品教程】081:WGS84/CGCS2000轉Lambert投影

參考閱讀:ArcGIS實驗教程——實驗十:矢量數據投影變換 文章目錄 一、加載實驗數據二、設置輸出坐標系三、數據導出一、加載實驗數據 打開配套案例數據包中的data081.rar中的矢量數據,如下所示: 查看源坐標系:雙擊圖層的,圖層投影選項卡,數據的已有坐標系為WGS84地理坐標…

MySQL創建存儲過程函數

DDL CREATE TABLE student (id int(11) NOT NULL AUTO_INCREMENT COMMENT 學號,createDate datetime DEFAULT NULL,userName varchar(20) DEFAULT NULL,pwd varchar(36) DEFAULT NULL,phone varchar(11) DEFAULT NULL,age tinyint(3) unsigned DEFAULT NULL,sex char(2) DEFAU…

[初學rust] 05_ rust struct

rust struct 其實這也算復合類型&#xff0c;但是其他語言都有&#xff0c;所以抽取出來單獨看的時候會很簡單&#xff0c;更容易學 1. 定義結構體 結構體的定義和其他語言沒啥區別。 struct User {name: String,age: i32, }2. 創建實例 創建實例的過程就跟js類似 let us…

【3dmax筆記】021:對齊工具(快速對齊、法線對齊、對齊攝影機)

文章目錄 一、對齊二、快速對齊三、法線對齊四、對齊攝影機五、注意事項3dmax提供了對齊、快速對齊、法線對齊和對齊攝像機等對齊工具: 對齊工具選項: 下面進行一一講解。 一、對齊 快捷鍵為Alt+A,將當前選擇對象與目標對象進行對齊。 最大對最大:

【小筆記】neo4j用load csv指令導入數據

【小筆記】neo4j用load csv指令導入數據 背景 很久沒有用load CSV的方式導入過數據了因為它每次導入有數量限制&#xff08;印象中是1K還是1W&#xff09;&#xff0c;在企業中構建的圖譜往往都是大規模的&#xff0c;此時通常采用的是Neo4j-admin import方式。最近遇到了一些…

振弦式表面應變計怎么安裝

振弦式表面應變計是一種用于測量結構表面應變的高精度傳感器&#xff0c;廣泛應用于工程和科研領域。正確安裝振弦式表面應變計對于確保測量結果的準確性至關重要。以下是安裝振弦式表面應變計的步驟和注意事項&#xff1a; 1. 準備工作 在開始安裝前&#xff0c;需要準備以下工…