【rust实战】rust博客系统4_连接数据库及查询数据

|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 问题 | 回答 | 解释 |
| 如何连接数据库 | 1.在Cargo.toml中添加 mysql 依赖项 mysql = "21.0.0" 2.在src/db/db.rs中写连接数据库的代码 use mysql::*; use mysql::prelude::* pub fn init_pool() -> Result<Pool> { let url = "mysql://root:123456@localhost:3306/dr_platform" Pool::new(url) } pub fn test_connection(pool: &Pool) -> mysql::Result<()>{ let mut conn = pool.get_conn()?; let result: Vec<User> = conn.query_map("SELECT * from users", |row|{ User::from_row(row) }) for user in &result { println!("{:?}", user); } Ok(()) } | ->:返回值 Result:枚举类型 可能会产生两种结果,成功或失败 enum Result<T, E> { OK(T), Err(E), } Result没有指定这两个参数时,通常是在泛型上下文中,具体类型在其他地方被指定了 mysql::Result<()>: T被替换成了(), 即单元类型,表示这个函数不返回值 let mut conn = pool.get_conn()?; ?用户传播错误 ? :如果get_conn返回的Err变体,则?会提前返回,并将错误传给调用者 为什么不用::而用. .调用对象的方法 ::访问关联函数或者静态方法 let result: Vec<User> 声明result变量 类型为 Vec<User> conn.query_map("SELECT * from users",|row| { 调用conn的query_map |row|为闭包参数 |
| | 3.在 src/models/user.rs中写接口体接收查到得数据 use mysql::{prelude::*}; #[derive(Debug)] pub struct User { pub id: i32, username: String } impl User { pub fn from_row(row: mysql::Row) -> Self { User { id:row.get("id").expect("REASON"), username:row.get("username").expect("REASON") } } } | expect:是一个Option类型上定义的方法 Option类型是一个枚举值类型,它可以有两个值,一个是Some(T) 一个是None, 当使用get检索数据时,如果键值存在,返回Some(T), 如果键值不存在,返回None,会引发一个带有指定消息(这里时REASON)的panic错误 |

相关推荐
techdashen3 小时前
Rust 泛型 vs Java 泛型:它们看起来相似,但骨子里截然不同
java·开发语言·rust
codealy3 小时前
Rust 核心理论与内存安全(二)
安全·rust
Rust研习社3 小时前
告别环境混乱!使用 mise 管理你的开发环境
前端·后端·rust
小杍随笔4 小时前
【Tauri 2.x 自定义 WebView2 用户数据目录完全指南】
架构·rust
樱桃花下的小猫5 小时前
Rust 服务器存档管理 & 地图配置指南
服务器·rust·云鸢互联·零门槛一键开服·腐蚀rust服务器·腐蚀rust稳定低延迟联机·腐蚀rust服务器一键开服
红尘散仙16 小时前
一个 `#[uniffi::export]`,把 Rust 接进 React Native
前端·后端·rust
红尘散仙16 小时前
一行 `#[specta::specta]`,让 Tauri IPC 有类型
前端·后端·rust
codealy1 天前
Rust 核心理论与内存安全(一)
后端·安全·rust
土豆.exe1 天前
IfAI v0.5.0 深度技术解析:120,000 行 Rust 打造的 AI-Native 编辑器
rust·编辑器·ai-native
咸甜适中1 天前
rust语言学习笔记Trait之 AsRef 和 AsMut(引用转换)
笔记·学习·rust