MySQL8 设置大小写敏感

news2025/1/16 8:19:50

问题描述

今天对我本地的数据库迁移服务器上,完成之后启动项目报错

在这里插入图片描述

说数据库中不存在 quartz_LOCKS 这张表

在这里插入图片描述

我打开服务器上面的数据上面展示的表名是 quartz_LOCKS,然后通过查询 lower_case_table_names 配置可知

show variables like 'lower_case_table_names';

在这里插入图片描述

lower_case_table_names=0,表示 表名区分大小写,且按照用户指定存储

lower_case_table_names 各参数含义:

  • 0:表名区分大小写,且按照用户指定存储
  • 1:表不区分大小写,使用小写存储
  • 2:表不区分大小写,按照用户指定存储

按理说只要将 lower_case_table_names 的值设置为 1 或者 2 就行了

接着我去修改了服务器上 my.cnf (或者 my.ini)文件

在这里插入图片描述

添加以下配置:

[mysqld]  
lower_case_table_names = 1

在这里插入图片描述

接着再重启 mysql

# 重启 mysql
systemctl restart mysqld

在这里插入图片描述

mysql 启动失败


原因分析:

根据提示使用 systemctl status mysqld.service 命令显示 mysqld.service 的状态信息,

在这里插入图片描述

退出状态码为 1,这通常意味着在启动过程中遇到了某种错误,为了确定具体的错误原因,查看更详细的日志

# 查询 mysql 日志
sudo tail -n 100 /var/log/mysqld.log

在这里插入图片描述

从日志上说明 MySQL 服务器启动失败的原因是 lower_case_table_names 的设置不一致。MySQLlower_case_table_names 配置项决定了表名在存储和比较时是否应该转换为小写,这个设置必须在服务器和数据字典之间保持一致,否则服务器将无法正确启动

[ERROR] [MY-011087] [Server] Different lower_case_table_names settings for server ('1') and data dictionary ('0').

指出服务器期望 lower_case_table_names 设置为 1(意味着表名在存储和比较时应转换为小写),但是数据字典(即已有的数据库表元数据)的 lower_case_table_names 设置是 0(意味着表名区分大小写)

mysqld.log 日志文件打印的信息来看,导致 Mysql 启动失败的原因就是因为设置了 lower_case_table_names=1 这个参数,之前在本地使用的 Mysql5.7 版本的,而服务器上面的 Mysql 版本确是 8.0

查看 Mysql 官方文档可知

lower_case_table_names can only be configured when initializing the server.
Changing the lower_case_table_names setting after the server is initialized is prohibited.

Mysql-8.0 版本时,lower_case_table_names 变量是一个系统变量,它只能在 MySQL 服务器初始化时设置,并且一旦服务器初始化完成,就不应该再更改这个设置。这是因为在 MySQL 的数据字典和文件系统层面,这个设置影响到了表名和目录名的大小写敏感性和转换规则。如果在服务器运行时改变这个设置,可能会导致数据不一致和其他严重问题


解决方案:

通过分析可知 Mysql8 在初始化之后是不能修改 lower_case_table_names 这个参数的

那要解决这个问题有两种方案,要么就是更改现有的表明,要么就初始化数据库,更改配置

  • 方案一

如果你的表比较少的话,可以通过 RENAME TABLE 语句来更改它们,例如:将 my_table 更新为 MY_TABLE

RENAME TABLE my_table TO MY_TABLE;

但是,如果你有很多表需要更改,这种方法可能会很繁琐

也可以编写一个脚本来查询数据库中的所有表名,并自动为它们生成 RENAME TABLE 语句,然后执行这些语句来更改表名

  • 方案二

初始化数据库,再更改 lower_case_table_names 配置,在初始化数据时,需要清空数据库中所有的数据并恢复到初始状态,所以务必做好数据备份

在初始化数据库时需要先将数据库关闭

# 关闭 mysql
systemctl stop mysqld

Mysql 数据库的数据库存储在 /var/lib/mysql 下,在重新初始化数据库之前,需要删除现有的数据目录

sudo rm -rf /var/lib/mysql

在这里插入图片描述

注意:此操作不可逆,务必做好数据备份

再重新创建一个新的数据目录

sudo mkdir /var/lib/mysql

在这里插入图片描述

授权 Mysql 对于 /var/lib/mysql 目录的所有权

sudo chown -R mysql:mysql /var/lib/mysql

在这里插入图片描述

初始化数据库

sudo mysqld --initialize

在这里插入图片描述

到此为止初始化的步骤已经完成,接着就去修改 /etc/my.cnf 文件中的 lower_case_table_names 配置

在这里插入图片描述

在 /var/log/mysqld.log 这个文件中查找 Mysql 的密码

cat /var/log/mysqld.log

在这里插入图片描述

rtAVCTaNg0*b

再启动 Mysql

# 启动 mysql
systemctl start mysqld

在这里插入图片描述

连接 Mysql

# 连接 MySQL 
mysql -u root -p

在这里插入图片描述

修改 root 密码

ALTER  USER  'root'@'localhost'  IDENTIFIED BY 'password';

在这里插入图片描述

再通过以下命令查看下 lower_case_table_names 的值是否为你所设置的

show variables like 'lower_case_table_names';

在这里插入图片描述

可以看到已经成功修改为 1

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1513631.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

图片格式转换怎么操作?这一个方法快快收藏

图片格式转换能够改变图片的质量、大小兼容性。不同的图片格式用途也不同,当我们需要转换图片格式的时候要怎么操作呢?下面,小编给大家分享一款操作简单,小白也能轻松上手的图片转换器(https://www.yasuotu.com/geshi&…

[ThinkPHP]Arr返回1

$detailId (int)Arr::get($detail, null); var_dump($detailId); 打印结果:int(1) 原因: vendor/topthink/think-helper/src/helper/Arr.php

Spring启动“--”设置参数没生效

现象 在idea中启动SpringBoot项目时,使用“--”设置的启动参数没有生效,如修改端口号“--server.port8082” 原因 排查发现是因为在使用SpringApplication.run启动项目时,没有将args参数传入run方法。 修复方案 SpringApplication.run参数中…

【漏洞复现】宏景HCM downlawbase SQL注入漏洞

0x01 产品简介 宏景人力资源管理软件是一款人力资源管理与数字化应用相融合,满足动态化、协同化、流程化、战略化需求的软件。 0x02 漏洞概述 宏景HCM downlawbase 接口处存在SQL注入漏洞,未经过身份认证的远程攻击者可利用此漏洞执行任意SQL指令&…

综合实验---Web环境搭建

题目: 服务器IP地址规划:client:12.0.0.12/24,网关服务器:ens36:12.0.0.1/24、ens33:192.168.10.1/24,Web1:192.168.10.10/24,Web2:192.168.10.20/24&#xf…

53、WEB攻防——通用漏洞CRLF注入URL重定向资源处理拒绝服务

文章目录 CRLF注入原理&检测&利用URL重定向web拒绝服务 CRLF注入原理&检测&利用 URL重定向 就是url中存在urlhttps://xxx,重定向的页面没有限制。主要用来做钓鱼。 web拒绝服务 例如,图片的长宽参数由前端传入,恶意的数据…

vmware虚拟机命令安装Vmware tools

安装Vmware tools sudo apt-get autoremove open-vm-tools sudo apt-get install open-vm-tools-desktop

记OnlyOffice的两个大坑

开发版,容器部署,试用许可已安装。 word,ppt,excel均能正常浏览。 自带的下载菜单按钮能用。 但config里自定义的downloadAs方法却不一而足。 word能正常下载,excel和ppt都不行。 仔细比对调试了代码。发现app.js…

VsCode远程免密登录

创建本地密匙 按下WinR输入cmd,输入 ssh-keygen -t rsa然后连续回车直到结束 找到Your public key has been saved in C:\Users\Administrator/.ssh/id_rsa.pub,每个人都不一样找到密匙所在地 打开id_rsa.pub这个文件,可以用记事本打开&am…

苹果放弃造车计划 或更加专注AI

近日,据有关消息称苹果公司决定放弃投入数十亿美元的造车项目,2000多名员工将逐步转到人工智能项目。特斯拉CEO马斯克、小米创始人雷军、理想汽车CEO李想、小鹏汽车CEO何小鹏等纷纷在社交平台发言感慨。 从2008年开始,苹果就有了造车野心&…

剪映能导入mxf格式吗?mxf格式怎么转换为mp4?

剪映支持导入MXF格式的视频文件。在导入MXF格式的视频时,如果遇到无法导入的情况,可能是由于封装的视频或音频不符合剪映支持的编码模式。这时,你可以使用音视频转换器,如野葱视频转换器、在线网站convertio、开源工具FFmpeg&…

(自用笔记)每天一点vue3—— echarts横坐标刻度标签显示不完全的问题

我是想做一个vue3echarts的账单数据展示项目,因为有vue2的基础,打算直接在这个项目上熟悉掌握vue3的新特性。这系列笔记就按照遇见问题解决问题的思路更新,不按照官方快速上手的章节,特此说明。 echarts 上次遗留一个横坐标刻度标…

1.1计算机系统构成及硬件系统知识(下)

1、定点数与浮点数 定点整数的小数点在最低有效数位之后,也就是00000000.; 因为定点整数只表示整数,不涉及小数; 定点小数的小数点在符号位之后,也就是最高有效数位之前,也就是0.0000000; 浮点…

【洛谷 P8781】[蓝桥杯 2022 省 B] 修剪灌木 题解(数学)

[蓝桥杯 2022 省 B] 修剪灌木 题目描述 爱丽丝要完成一项修剪灌木的工作。 有 N N N 棵灌木整齐的从左到右排成一排。爱丽丝在每天傍晩会修剪一棵灌木,让灌木的高度变为 0 0 0 厘米。爱丽丝修剪灌木的顺序是从最左侧的灌木开始,每天向右修剪一棵灌木…

十、软考-系统架构设计师笔记-软件架构演化和维护

1、软件架构演化 软件架构的演化和维护的目的是为了使软件能够适应环境的变化而进行的纠错性修改和完善性修改。软件架构的演化和维护过程是一个不断迭代的过程,通过演化和维护,软件架构逐步得到完善,以满足用户需求。软件架构的演化就是软件…

绝对省事!多微信聚合聊天神器大揭秘!

在如今社交网络发达的时代,微信已成为人们生活中不可或缺的通讯工具。然而,对于拥有多个微信账号的用户来说,经常需要来回切换不同账号,给日常使用带来一定的不便。 那么,有没有一种办法能够让我们摆脱这种繁琐的操作…

【活动】2024年AI辅助研发:深度变革与无限潜力

🌈个人主页: 鑫宝Code 🔥热门专栏: 闲话杂谈| 炫酷HTML | JavaScript基础 ​💫个人格言: "如无必要,勿增实体" 文章目录 作为一名前端程序员,深入探讨2024年AI在软件研发领域的应用趋势及其影…

【C#】.net core 6.0 使用第三方日志插件Log4net,配置文件详细说明

欢迎来到《小5讲堂》 大家好,我是全栈小5。 这是《C#》系列文章,每篇文章将以博主理解的角度展开讲解, 特别是针对知识点的概念进行叙说,大部分文章将会对这些概念进行实际例子验证,以此达到加深对知识点的理解和掌握。…

复杂网络——半局部中心法

一、概述 由于最近写论文需要使用复杂网络知识中的半局部中心法,但是截止目前来说,网上几乎搜索不到有关的MATLAB程序代码,只有一篇用Python编写的程序,我的电脑中没有python,所以我花费一些时间,利用matla…

互联网行业的应届大学生,如何制作高水平简历?

雇主通常只会花大约25秒的时间浏览一份简历,因此,拥有一份出色的简历对于找到理想工作至关重要。如果您的简历没有令人印象深刻的特点,那么如何才能在竞争激烈的求职市场中脱颖而出呢? 如果您不知道如何在简历上有效地展示自己,或者觉得简历无论怎么修改都不够突出,那么请…