Chr*_*e L 4 mysql innodb foreign-key mysqld
我正在使用 MySQL 版本 5.5.44 运行 Ubuntu
mysqld Ver 5.5.44-0ubuntu0.14.10.1 for debian-linux-gnu on x86_64 ((Ubuntu))
我有一个带外键的数据库。我希望在系统级别(而不是在会话中)禁用外键检查。
我看到系统 var foreign_key_checks似乎控制了这种行为,但是当我/etc/mysql/my.cnf
(通过添加foreign_key_checks = 0
)设置它时,服务器将无法启动。错误日志如下所示:
150729 15:38:18 [Warning] Using unique option prefix myisam-recover instead of myisam-recover-options is deprecated and will be removed in a future release. Please use the full name instead.
150729 15:38:18 [Note] Plugin 'FEDERATED' is disabled.
150729 15:38:18 InnoDB: The InnoDB memory heap is disabled
150729 15:38:18 InnoDB: Mutexes and rw_locks use GCC atomic builtins
150729 15:38:18 InnoDB: Compressed tables use zlib 1.2.8
150729 15:38:18 InnoDB: Using Linux native AIO
150729 15:38:18 InnoDB: Initializing buffer pool, size = 128.0M
150729 15:38:18 InnoDB: Completed initialization of buffer pool
150729 15:38:18 InnoDB: highest supported file format is Barracuda.
150729 15:38:18 InnoDB: Waiting for the background threads to start
150729 15:38:19 InnoDB: 5.5.44 started; log sequence number 56348937
150729 15:38:19 [ERROR] /usr/sbin/mysqld: unknown variable 'foreign_key_checks=0'
150729 15:38:19 [ERROR] Aborting
Run Code Online (Sandbox Code Playgroud)
如何配置我的 MySQL 服务器以在系统级别关闭外键检查?
编辑:行为与 MySQL 5.6.25 相同:
mysqld Ver 5.6.25-0ubuntu0.15.04.1 for debian-linux-gnu on x86_64 ((Ubuntu))
Foreign_key_checks不是您可以在启动时预设的全局选项。为什么 ?
当您单击该链接指向foreign_key_checks上的文档时,没有图表表明它是全局或会话范围。其他选项将在图表中指定范围
使用foreign_key_checks,它只是会话范围。
进一步的证明是当您转到命令行并运行它时
mysqld --help --verbose > /tmp/mysqld.txt
vi /tmp/mysqld.txt
Run Code Online (Sandbox Code Playgroud)
当您查看文本文件时,您看不到--foreign-key-checks
命令行启动选项。我向您展示的其他四个变量可以在命令行和my.cnf
.
如果你有数据要加载,你可以在加载前设置:
SET foreign_key_checks = 0;
source mydata.sql
Run Code Online (Sandbox Code Playgroud)
证明这是一个标准的 mysqldump 标头(前 10 行)
/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;
/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;
/*!40103 SET TIME_ZONE='+00:00' */;
/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;
Run Code Online (Sandbox Code Playgroud)
请注意第 8 行
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
Run Code Online (Sandbox Code Playgroud)
mysqldump 的底部是什么样的?像这样:
/*!40101 SET SQL_MODE=@OLD_SQL_MODE */;
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
/*!40014 SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS */;
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
/*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;
Run Code Online (Sandbox Code Playgroud)
请注意线
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
Run Code Online (Sandbox Code Playgroud)
底线:foreign_key_checks并不意味着在my.cnf
. 这是最有意义的,因为(如果允许)使用它启动 mysqld 会破坏启动时的参照完整性。