1. 问题描述
5.7.31 版本 mysql
数据库创建临时表报错
-- 报错语句
CREATE TEMPORARY TABLE temp_table_name
SELECT *
FROM table_name
LIMIT 0;
报错截图
[HY000][1005] Can’t create table ‘new_tbl’ (errno: 13)
2. 解决方案
步骤一:
查询 linux
mysql
数据库所属用户是否具有执行权限,若不具有执行权限则需赋予执行权限
步骤二:
查看 linux
系统 SELinux
策略,确认 SELinux
策略是否被设置为 enforcing
模式,若是则需要修改为 permissive
模式。
-- 查看 SELinux 状态(enforcing:强制模式、permissive:宽容模式、disabled:关闭状态)
sudo getenforce
-- 修改 SELinux 模式(重启服务器后会恢复成配置文件配置的模式)
-- 修改成强制模式
sudo setenforce enforcing
-- 修改成宽容模式
sudo setenforce permissive
持久性修改 SELinux 模式
编辑 SELinux
配置文件,将配置文件中的模式修改为 permissive
模式,保存后需重新服务器才会生效。
-- 配置文件位置
vim /etc/selinux/config