解决bug:the --secure-file-priv option so it cannot execute this statement

本文涉及的产品
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
简介: 解决bug:the --secure-file-priv option so it cannot execute this statement

一、Bug问题


系统环境:win11

运行环境:MySQL  8.0.28

图形工具:Navicat Premium 15

Bug描述: 在备份数据库时,运行SQL语句时报错:

eg:SQL语句:

select * from mysql_test.customers into outfile 'C:/BACKUP/backupfile.txt'
fields terminated by ','  optionally enclosed by '''' lines terminated by '?';


报错信息:


image.png

二、Bug分析


1.首先,翻译信息


报错信息:


The MySQL server is running with the --secure-file-priv option so it cannot execute this statement

翻译:MySQL服务器运行在secure-file-priv选项时,无法执行此语句。


2.然后,分析报错信息


1)mysql文件的导入和导出路径有默认的设置,secure-file-priv出现问题,说明SQL语句中传入的文件路径与默认的路径冲突,才会报错。

secure-file-priv的值有3种情况:

secure_file_prive=null            —— 默认值为null,限制mysql,禁止导入导出文件

secure_file_prive=“”               —— 表示不限制路径,允许mysql 导入导出文件

secure_file_prive=“D:/path”   —— 指定路径,表示只允许在该路径目录下导入导出文件(这里的路径值可以自己设置)

2)查看secure-file-priv当前的值

可以使用下面两种命令行方式查看secure-file-priv当前的值任选其一即可

第一种查看方式:

show variables like '%secure%';


显示结果

image.png

第二种查看方式:

show variables like "secure_file_priv";

显示结果

image.png

3)从上面显示结果中,可以明确系统默认禁止mysql导入导出文件。重新设置一下secure-file-priv的值即可。


三、解决方案


1) 首先,找到你的mysql安装路径下的my.ini文件

注:若安装路径下没有找到此文件,可以在此安装路径下自己新建一个my.ini文件。

下图是本人的mysql安装路径,仅供参考


image.png


2) 打开my.ini文件,在文件末尾设置secure-file-priv的值。

secure-file-priv的值可以指定路径设置,也可以不限制路径。区别是指定路径相对安全,但在mysql导入导出文件时则必须在指定路径下才可以,否则依然会报错。

注:本人直接设置不限制路径,你可以自行决定是否设置指定路径

secure_file_prive=“”


image.png


3) 然后,my.ini文件 点击另存为窗口,编码选择ANSI,保存。**

image.png


4) 验证secure-file-priv当前的值是否设置成功。

注:成功设置后,就可以使用SQL语句了。

命令行查看:

show variables like "secure_file_priv";

验证结果:

image.png

相关实践学习
自建数据库迁移到云数据库
本场景将引导您将网站的自建数据库平滑迁移至云数据库RDS。通过使用RDS,您可以获得稳定、可靠和安全的企业级数据库服务,可以更加专注于发展核心业务,无需过多担心数据库的管理和维护。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
关系型数据库 MySQL
MySQL错误 -.--secure-file-priv 无导出权限
MySQL错误 -.--secure-file-priv 无导出权限
911 0
|
10月前
|
存储 关系型数据库 MySQL
【赵渝强老师】使用select...into outfile语句备份MySQL
本文介绍了MySQL中使用`SELECT...INTO OUTFILE`语句将表数据导出为文本文件的方法。通过示例演示了如何备份员工表(emp)的数据,包括创建存储目录、设置权限、配置参数`secure_file_priv`以及解决相关错误的过程。字段分隔符和行终止符可自定义,确保数据格式符合需求。最后展示了备份文件的内容,验证操作成功。
602 36
|
消息中间件 缓存 NoSQL
如何实现消费幂等 ?
这篇文章,我们聊聊消息队列中非常重要的最佳实践之一:**消费幂等**。
如何实现消费幂等 ?
|
Java 调度
利用 XXL-JOB 实现灵活控制的分片处理
本文讲述了一种利用 XXL-JOB 来进行分片任务处理的方法,另外加入对执行节点数的灵活控制。
911 2
|
PHP 开发者
slowlog 和 request_slowlog_timeout
slowlog 和 request_slowlog_timeout
519 4
|
Java API 开发工具
Spring Boot与Spring Cloud Config的集成
Spring Boot与Spring Cloud Config的集成
|
关系型数据库 MySQL
解决MySQL8.0本地计算机上的MySQL服务启动后停止没有报告任何错误
解决MySQL8.0本地计算机上的MySQL服务启动后停止没有报告任何错误
16786 1
|
存储 SQL 关系型数据库
MySQL数据库——存储过程-循环(while、repeat、loop)
MySQL数据库——存储过程-循环(while、repeat、loop)
2395 0
|
存储 应用服务中间件 nginx
【各种问题处理】nginx报错nginx: [error] open() “/run/nginx.pid” failed (2: No such file or directory)
【1月更文挑战第13天】【各种问题处理】nginx报错nginx: [error] open() “/run/nginx.pid” failed (2: No such file or directory)