Rust中使用ORM框架diesel报错问题

server/2025/2/7 23:11:24/

1 起初环境没有问题:在Rust开发的时候起初使用的是mingw64平台加stable-x86_64-pc-windows-gnu编译链,当使用到diesel时会报错,如下:

x86_64-w64-mingw32/bin/ld.exe: cannot find -lmysql具体信息很长这是主要信息是rust找不到链接mysql的驱动在哪里

解决方式:解决找到mysql的安转目录,找到lib目录下的libmysql.dll,把它放到:

C:\Users\hp\.rustup\toolchains\stable-x86_64-pc-windows-gnu\lib\rustlib\x86_64-pc-windows-gnu\lib目录下,问题解决。

担是这是我安装Rust时默认的mingw64编译环境,现在我使用Tauri框架开发跨平台桌面程序,在windows中肯定不行,于是我切换到了visual studio环境下的编译工具链,首先是vs安装了c++的windows的桌面开发环境,具体操做:

切换rust的编译工具:

rustup default stable-x86_64-pc-windows-msvc

默认没有安装该工具就会下载,大小将近2G如果想使用两个环境可以保留两个工具链,如果嫌弃文件过大可删除,如下:

rustup toolchain uninstall stable-x86_64-pc-windows-msvc

生成的文件路径如下:

修改C:\Users\hp\.rustup目录下的settings文件如下:

default_host_triple = "x86_64-pc-windows-msvc"
default_toolchain = "stable-x86_64-pc-windows-msvc"
profile = "default"
version = "12"[overrides]

其中default_host_triple = "x86_64-pc-windows-gnu"要填写正确,否则vscode打开后Rust的代码解析插件始终无法启动:

切换vs环境后就可以使用Tauri 2.x框架开发基于webView的跨平台的桌面程序,同时支持android的快捷开发,后端使用Rust语言,前端使用js,方便地搭建了安卓开发环境和windows桌面开发环境。

2 切换后报符号链接问题:切换工具链后,在Rust使用ORM的diesel框架,又报一些链接错误的问题,比如mysqlClient链接错误,如果你本地安装了mysql就找到lib目录下的mysqlclient.lib配置环境变量和客户端版本号,如果没有安装mysql就去下载MySQL :: Download MySQL Connector/C (Archived Versions)保持all选项

如下:

MYSQLCLIENT_LIB_DIR=C:\Program Files\MySQL\MySQL Server 5.7\lib
MYSQLCLIENT_VERSION=8.0

配置完成后重新编译,此时发现链接不到库的问题解决,但同时发生代码报错问题,代码符号找不到,链接错误等一大堆问题,主要定位到mysqlclient-sys库下的build.rs文件下的95行,当前环境检测失败,无法编译报错。

按照这个可能可行,但由于磁盘有限下载一般就暂停了,这种环境问题的第三方包下载太麻烦,并且报错很可能与vs版本有关,于是就放弃vs的编译工具链。

3: 切换回原来的工具链:如果暂时不开发windows桌面和安卓程序,完全可以使用mingw64平台的工具链环境,这样不容易出错。切换方式比较简单,如下:

rustup default stable-x86_64-pc-windows-gnu  没有就会下载,并修改settings文件中的默认信息,这时可以删除vs的工具链rustup toolchain uninstall stable-x86_64-pc-windows-msvc,注意settings的配置信息,否则vscode的代码解析器插件服务无法启动。

rustup常见命令:

# 查看rustc版本
rustc --version# 显示当前安装的工具链信息
rustup show
# 检查安装更新
rustup update
# 卸载
rustup self uninstall
# 设置当前默认工具链
rustup default stable-x86_64-pc-windows-gnu
# 查看帮助
rustup -h# -------------------------->配置工具链
# 查看工具链
rustup toolchain list
# 安装工具链
rustup toolchain install stable-x86_64-pc-windows-gnu
# 卸载工具链
rustup toolchain uninstall stable-x86_64-pc-windows-gnu
# 设置自定义工具链
rustup toolchain link <toolchain-name> "<toolchain-path>"# -------------------------->配置一个目录以及其子目录的默认工具链
# 查看已设置的默认工具链
rustup override list
# 设置该目录以及其子目录的默认工具链
rustup override set <toolchain> --path <path>
# 取消目录以及其子目录的默认工具链
rustup override unset --path <path># -------------------------->配置工具链的可用目标
# 查看目标列表
rustup target list
# 安装目标
rustup target add <target>
# 卸载目标
rustup target remove <target>
# 为特定工具链安装目标
rustup target add --toolchain <toolchain> <target># -------------------------->配置 rustup 安装的组件
# 查看可用组件
rustup component list
# 安装组件
rustup component add <component>
# 卸载组件
rustup component remove <component>

cargo的基础命令:在用户主目录的 .cargo 目录下新建一个文件,命名为 config(没有扩展名),并输入以下内容配置下载的数据源,不配置下载速度可行

[source.crates-io]
registry = "https://github.com/rust-lang/crates.io-index"
replace-with = 'ustc'## 二选择一
## replace-with = 'XXX' 选择配置# 中国科学技术大学
[source.ustc]
registry = "git://mirrors.ustc.edu.cn/crates.io-index"# 清华大学
[source.tuna]
registry = "https://mirrors.tuna.tsinghua.edu.cn/git/crates.io-index.git"
 查看cargo版本
cargo --version# 新建项目
cargo new <project_name># 构建项目
cargo build# 运行项目
cargo run# 检查项目
cargo check# 查看帮助
cargo -h

一切切换回来后重新编译原来的Diesel库项目发现没有任何报错,担是在vs平台的编译链上的问题任然存在,如果你想一直基于vs平台下的编译链,建议在安装Rust时就和当前vs环境友好搭配下载安装,而我的是基于mingw64安转的忽略了很多环境切换上的问题,到此windows中使用Rust的ORM框架diesel报错问题初步解决。

4:问题解决:如果你windows上安装了mysql服务,就找到安装目录下的lib目录,在项目中创建build.rs文件指定依赖库的路径,如下代码:

fn main() {// 设置 MySQL 客户端库的搜索路径,找到libmysql.dll和libmysql或mysqlclientprintln!("cargo:rustc-link-search=native=C:\\Program Files\\MySQL\\MySQL Server 5.7\\lib");// 设置需要链接的库名println!("cargo:rustc-link-lib=dylib=libmysql"); // 使用 dylib 表示动态链接
}

如果你本地没有安装过mysql数据库,就从上面地址下载 MySQL :: Download MySQL Connector/C (Archived Versions) 的mysqlClient库,需要注意的是如果你使用vs的编译工具链就确保在链接时使用的是windows下的mysqlClient客户端,即lib下的mysqlclient.lib库文件如果使用的是mingw64平台的stable-x86_64-pc-windows-gnu编译链就去链接libmysql库,如果你链接的是mysqlclient.lib就会报符号链接错误,因为当前使用的是mingw64环境属于跨平台的linux环境需要使用libmysql.lib库,如果是vs环境需要去下载MySQL Connector C 6.1找到lib中的vs14下的mysqlclient.lib,这是windows平台下的,如果报符号错误问题,换一个版本,基本解决(注意:如果你配置了环境变量确保MYSQLCLIENT_LIB_DIR指定的mysql客户端的库的类型 一般下载来的使用C:\Program Files\MySQL\MySQL Connector C 6.1\lib\vs14路径是windows平台下的,如果项目本地没有build.rs配置则该环境变量起作用会发生符号链接错误,而当前你使用的是 stable-x86_64-pc-windows-gnu工具链,是linux环境你因该设置=C:\Program Files\MySQL\MySQL Server 5.7\lib)指定libmysql.lib库如果里面连个都用,最好在创建一个build.rs文件明确指定,否则用到了libmysqlclient下的库仍然报符号错误。


http://www.ppmy.cn/server/165789.html

相关文章

14JavaWeb——SpringBoot原理

SpingBoot原理 在前面十多天的课程当中&#xff0c;我们学习的都是web开发的技术使用&#xff0c;都是面向应用层面的&#xff0c;我们学会了怎么样去用。而我们今天所要学习的是web后端开发的最后一个篇章springboot原理篇&#xff0c;主要偏向于底层原理。 我们今天的课程安…

解锁Spring Boot 3.1 + JDK 17:分布式系统的变革力量

分布式系统发展的现状与挑战 在当今数字化时代&#xff0c;分布式系统已成为互联网技术领域的核心支撑。从电商平台的海量交易处理&#xff0c;到社交网络的实时互动&#xff0c;再到金融领域的安全交易保障&#xff0c;分布式系统无处不在&#xff0c;它如同无形的纽带&#…

【基于SprintBoot+Mybatis+Mysql】电脑商城项目之修改密码和个人资料

&#x1f9f8;安清h&#xff1a;个人主页 &#x1f3a5;个人专栏&#xff1a;【Spring篇】【计算机网络】【Mybatis篇】 &#x1f6a6;作者简介&#xff1a;一个有趣爱睡觉的intp&#xff0c;期待和更多人分享自己所学知识的真诚大学生。 目录 &#x1f383;1.修改密码 -持久…

手写单例模式

饿汉式加载模式&#xff08;线程安全&#xff09; 类一加载就创建对象&#xff0c;这种方式比较常用 优点&#xff1a;线程安全&#xff0c;没有加锁&#xff0c;执行效率高 缺点&#xff1a;不是懒加载&#xff0c;类初始化的时候就加载&#xff0c;浪费内存空间 package …

寒假2.5

题解 web:[网鼎杯 2020 朱雀组]phpweb 打开网址&#xff0c;一直在刷新&#xff0c;并有一段警告 翻译一下 查看源码 每隔五秒钟将会提交一次form1&#xff0c;index.php用post方式提交了两个参数func和p&#xff0c;func的值为date&#xff0c;p的值为Y-m-d h:i:s a 执行fu…

React Native 列表组件:FlashList、FlatList 及更多

在移动开发中&#xff0c;高效展示数据列表至关重要。作为 React Native 开发者&#xff0c;我们可以使用多种强大的工具来完成这一任务。无论是 ScrollView、SectionList 还是 FlatList&#xff0c;React Native 都提供了一系列用于数据展示的组件。 然而&#xff0c;随着数据…

鸿蒙生态潮起:开发者的逐浪之旅

鸿蒙生态潮起&#xff1a;开发者的逐浪之旅 在全球科技的澎湃浪潮中&#xff0c;鸿蒙生态宛如一座正在崛起的新大陆&#xff0c;熠熠生辉&#xff0c;吸引着无数开发者扬帆起航&#xff0c;探寻其中蕴藏的无限机遇&#xff0c;也直面诸多挑战。 鸿蒙生态的机遇&#xff0c;首先…

Tomcat 的几种部署方式

Apache Tomcat 是一个广泛使用的开源 Servlet 容器&#xff0c;用于部署和运行 Java Web 应用程序。Tomcat 支持多种部署方式&#xff0c;每种方式都有其特点和适用场景。以下是几种常见的 Tomcat 部署方式的详细讲解&#xff1a; 1. 通过 webapps 目录自动部署 这是最简单也…