文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Rust怎么连接PostgreSQL数据库

2023-06-28 22:48

关注

这篇文章主要讲解了“Rust怎么连接PostgreSQL数据库”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Rust怎么连接PostgreSQL数据库”吧!

pgxr 是一个 Rust 的 crate 库,可以实现用 Rust 语言来编写 PostgreSQL 的扩展函数(相当于存储过程)。

这次,我们使用 postgres 这个 crate 来连接和操作 PostgreSQL 数据库。

创建好项目后,在 cargo.toml 里添加 postgres 的依赖:

Rust怎么连接PostgreSQL数据库

首先,导入相关的类型,并创建一个 Person struct:

Rust怎么连接PostgreSQL数据库

再创建 create_db 函数,用来创建数据库和表,它返回一个 Result,里面可能是 Client 或错误:

注意,Client::connect() 函数所接受的连接字符串可以是两种形式的:

Rust怎么连接PostgreSQL数据库

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 函数,来插入一些数据:

Rust怎么连接PostgreSQL数据库

注意该函数的参数 Client 必须是 mut 的。

再创建一个查询数据的函数:

Rust怎么连接PostgreSQL数据库

这里,我们直接对 Client 的 query 方法返回的结果进行遍历,最后方法返回一个 Vec。

最后,在 main 函数里依次调用这些函数,并把查询结果打印出来:

Rust怎么连接PostgreSQL数据库

结果如下:

Rust怎么连接PostgreSQL数据库

全部代码如下:

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);

感谢各位的阅读,以上就是“Rust怎么连接PostgreSQL数据库”的内容了,经过本文的学习后,相信大家对Rust怎么连接PostgreSQL数据库这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯