rust sqlx包(数据库相关)使用方法+问题解决

2024-01-07 03:36

本文主要是介绍rust sqlx包(数据库相关)使用方法+问题解决,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

可以操作pgsql、mysql、mssql、sqlite
异步的,性能应该不错,具体使用有几个坑
除了sqlx库,还有对于具体数据库的库,比如postgres库
演示以pgsql为例,更新时间2024.1.6


官方github: sqlx github
rust官方文档:rust sqlx库文档

一、项目配置

1.添加依赖

cargo.toml的[dependencies]
sqlx依赖tokio的异步运行时,或者async-std的运行时,所以要加上

sqlx = { version = "0.7.3",features = ["postgres", "runtime-async-std"] }
# 下面二选一了
tokio = {version = "1.35.1",features = ["full"]}
async-std = { version = "1.12.0" }

2.引入模块

根据需要引入,通常

use sqlx;

3.函数运行时

#[tokio::main]
fn xxx(){
}

二、数据库连接和sql操作

更多的操作看官方文档。
以pgsql为例,mysql等其他数据库需要调整函数

1.数据库连接(连接池)

sqlx库自带连接池,这样可以省去在数据库外再布置连接池
这里封装成函数使用,作为一个pub函数,调用的函数用运行时即可,注意修改数据库账号密码

/// pgsql连接
pub async fn pgsql_conn() -> sqlx::Pool<Postgres> {return  PgPoolOptions::new().max_connections(10).connect("postgres://postgres:password@192.168.x.x:5432/datebase_name").await.unwrap();
}

调用时(注意是异步的)

let pg_conn=crate::xxx::pgsql_conn().await;

2.执行sql

封装好的函数,执行sql(适用于pgsql)

/// pgsql的sql执行
/// @param database_conn 数据库连接
/// @param sql 执行的sql
pub async fn pgsql_sql_execute(database_conn: sqlx::PgPool,sql:&str) -> Vec<sqlx::postgres::PgRow> {return sqlx::query(&sql).fetch_all(&database_conn).await.unwrap();
}

调用时(注意xxx改为自己的目录)

let pool=crate::xxx::pgsql_conn().await;
let sql="select * from xxx limit 10";
let reses=crate::xxx::pgsql_sql_execute(pool,sql).await;
// 迭代每行,假设这个表有一个"id"的字段
for res in reses
{let column: i32 = res.get("id");println!("{}",column);
}

三、错误及解决

1.either the runtime-async-std or runtime-tokio feature must be enabled

这个问题出在sqlx的依赖(当初这个迷惑了一段时间),同时需要
在crago的[dependencies]里面:
在这里插入图片描述或者
在这里插入图片描述同时需要函数的异步运行时

在这里插入图片描述

当然,有好几个可以用,可以参考github的说明,有多个运行时可以选取
在这里插入图片描述

这篇关于rust sqlx包(数据库相关)使用方法+问题解决的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/578594

相关文章

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有