MySQL 5.7升级8.0报异常:处理新增关键字
wptr33 2025-01-04 23:28 12 浏览
异常
MySQL 8.0版本相比5.7版本新增和删除了一些关键字,如果原来系统中一些表名或者字段名成为8.0中的关键字的话,系统会报如下异常:
You have an error in your SQL syntax; check the manual that
corresponds to your MySQL server version for the right
syntax to use near ', title from test LIMIT 0, 100'
异常解决
通常我们需要修改下面两种场景来解决这个异常
1、实体Model
在报错的实体Model的相应字段上增加@Column注解,@Column 注解用来标识实体类中属性与数据表中字段的对应关系,注解中的name属性定义了被标注字段在数据库表中所对应字段的名称,nullable属性表示该字段是否可以为 null 值,默认为 true。
需要在报错的字段的name属性的值上即字段名上增加反单引号,这样即使字段名跟新增关键字名称一样,也不会报错了,示例:
@Column(name = "`rank`", nullable = false)
private String rank;
2、手写SQL
在报错的Sql的相应字段上增加反单引号,示例:
Select `rank`, title from test LIMIT 0, 100
MySQL8.0新增关键字列表
=== A
ARRAY; added in 8.0.17 (reserved); became nonreserved in 8.0.19
=== C
CUBE (R); became reserved in 8.0.1
CUME_DIST (R); added in 8.0.2 (reserved)
=== D
DENSE_RANK (R); added in 8.0.2 (reserved)
=== E
EMPTY (R); added in 8.0.4 (reserved)
=== F
FIRST_VALUE (R); added in 8.0.2 (reserved)
FUNCTION (R); became reserved in 8.0.1
=== G
GET_MASTER_PUBLIC_KEY; added in 8.0.4 (reserved); became nonreserved in 8.0.11
GROUPING (R); added in 8.0.1 (reserved)
GROUPS (R); added in 8.0.2 (reserved)
=== I
INTERSECT (R); added in 8.0.31 (reserved)
=== J
JSON_TABLE (R); added in 8.0.4 (reserved)
=== L
LAG (R); added in 8.0.2 (reserved)
LAST_VALUE (R); added in 8.0.2 (reserved)
LATERAL (R); added in 8.0.14 (reserved)
LEAD (R); added in 8.0.2 (reserved)
=== M
MEMBER; added in 8.0.17 (reserved); became nonreserved in 8.0.19
=== N
NTH_VALUE (R); added in 8.0.2 (reserved)
NTILE (R); added in 8.0.2 (reserved)
=== O
OF (R); added in 8.0.1 (reserved)
OVER (R); added in 8.0.2 (reserved)
=== P
PERCENT_RANK (R); added in 8.0.2 (reserved)
PERSIST_ONLY; added in 8.0.2 (reserved); became nonreserved in 8.0.16
=== R
RANK (R); added in 8.0.2 (reserved)
RECURSIVE (R); added in 8.0.1 (reserved)
ROW (R); became reserved in 8.0.2
ROWS (R); became reserved in 8.0.2
ROW_NUMBER (R); added in 8.0.2 (reserved)
=== S
SYSTEM (R); added in 8.0.3 (reserved)
=== W
WINDOW (R); added in 8.0.2 (reserved)
批量校验
批量校验项目的数据库实例中是否有MySQL8.0新增关键字
校验表名:
SELECT TABLE_NAME
FROM information_schema.TABLES
WHERE TABLE_NAME in ("ARRAY","CUBE","CUME_DIST","DENSE_RANK","EMPTY","FIRST_VALUE","FUNCTION",
"GET_MASTER_PUBLIC_KEY","GROUPING","GROUPS","INTERSECT","JSON_TABLE","LAG","LAST_VALUE","LATERAL",
"LEAD","MEMBER","NTH_VALUE","NTILE","OF","OVER","PERCENT_RANK","PERSIST_ONLY","RANK","RECURSIVE",
"ROW","ROWS","ROW_NUMBER","SYSTEM","WINDOW");
校验字段名:
SELECT TABLE_NAME, COLUMN_NAME
FROM information_schema.COLUMNS
WHERE COLUMN_NAME in ("ARRAY","CUBE","CUME_DIST","DENSE_RANK","EMPTY","FIRST_VALUE","FUNCTION",
"GET_MASTER_PUBLIC_KEY","GROUPING","GROUPS","INTERSECT","JSON_TABLE","LAG","LAST_VALUE","LATERAL",
"LEAD","MEMBER","NTH_VALUE","NTILE","OF","OVER","PERCENT_RANK","PERSIST_ONLY","RANK","RECURSIVE",
"ROW","ROWS","ROW_NUMBER","SYSTEM","WINDOW");
若您想了解更多内容,请关注公众号:图南随笔,vx:tunan66666
若您觉得还可以,请帮忙点个“赞”,谢谢~
关注我,查看更多技术干货文章
- 上一篇:mysql进阶系列:基础架构
- 下一篇:MySQL这些底层执行原理,早已成必备了!
相关推荐
- 为什么劝你不要买Switch OLED?(现在买switch oled划算吗)
-
那么在聊我们自己的观点前,还是先来看看这款任天堂SwitchOLED款式究竟带来了哪些变化吧。SwitchOLED已经把它最大的特点之一写到了名字里——OLED。这款产品改动最大的地方,就是在维...
- 新游戏、怀旧机!没有Switch新机的任天堂还能俘虏玩家们的心吗?丨C位
-
6月16日凌晨,日本电子游戏巨头任天堂在E3游戏展会上举行了发布会。翘首以盼的SwitchPro并未亮相,截止发稿,任天堂股价跌2.44%。但玩家们最为期待的《塞尔达:荒野之息2》将于2022年推出...
- 腾讯引进Nintendo Switch (OLED版)开启预售 多重满足您的娱乐需求
-
1月4日,腾讯引进NintendoSwitch(OLED版)开启预售,并将于1月11日正式发售。NintendoSwitch(OLED版)是NintendoSwitch的全新款式,配置色彩艳丽的...
- 股东大会上任天堂考虑移植更多WiiU和GC游戏到Switch
-
任天堂股东大会上有任天堂的忠实小股东玩家提议想在Switch玩到WiiU以及GC的经典游戏,对于这个问题,官方给了正面的回应。官方表示目前皮克敏等部分游戏已经可以在switch上玩了,今后会认真考虑玩...
- 《野狗子》M站均分低至60分!IGN仅给5分、VGC感觉像是PS3游戏
-
外山圭一郎工作室首部作品《野狗子》全球媒体口碑已解禁,总体评价一般,目前M站均分已降低至60分,21条评价,好评5条,中评14条,差评2条。IGN为其打出5分评价。《野狗子》的特色在于一些有趣的附身交...
- 《EA SPORTS FC 25》加入任天堂游戏试玩会,Switch版可免费体验
-
近日,EASPORTS宣布其最新力作《EASPORTSFC25》的Switch版本已正式加入任天堂游戏试玩会。即日起至3月2日,所有NintendoSwitchOnline订阅用户均可限时...
- Double Kill!马里奥乐园+Switch能解任天堂焦虑吗?丨C位
-
近日,“超级任天堂世界”主题乐园在大阪环球影城开园,“超级马里奥之父”宫本茂现身揭幕仪式。任天堂近来喜事连连,2020年财年前九个月实现营收838亿元,贡献最大的Switch销量远超索尼PS5与微...
- 迷你主机、Switch好搭子:16寸4K超亮QLED CFORCE便携屏值得入手吗
-
一、迷你主机、Switch好搭子...
- 怎样查看Switch的“主机序列号信息”
-
小时候看到游戏机就走不动,现在玩游戏越来越方便了,比如Switch.今天讲讲怎样查看Switch的“主机序列号信息”。第一步:点击【设置】...
- Switch版《EA SPORTS FC 25》容量相比前作缩水
-
备受期待的Switch版足球游戏《EASPORTSFC25》即将发布,根据任天堂官方网站的游戏信息显示,与前作《EASPORTSFC24》相比,游戏容量有所下降。在任天堂官方网站可以查到,...
- switch双系统升级注意点(switch双系统升级注意点是什么)
-
升级系统有风险,建议只有实在想玩的游戏玩不了的时候再升级。1、针对双系统进行,单系统不适用。2、国行系统同pj系统的升级是分开的,互不干涉。国行系统进入后直接升级即可。3、升级之前,建议先做好各类备份...
- 《鬼泣4:特别版》游戏评测:全家老小齐上阵
-
游戏名称:鬼泣4:特别版英文名称:DevilMayCry?4SpecialEdition游戏类型:动作游戏ACT制作公司:CAPCOMCo.,Ltd.发行公司:CAPCOMCo.,L...
- 最好不要在超过35°C的环境温度里玩你的掌机
-
随着进入“初伏”,天气越发酷热,今年全球高温尤为严重。Valve对此发布了一个安全警告,告诉玩家SteamDeck可以在哪些温度下安全运行。Valve指出,SteamDeck的最佳工作环...
- 任天堂回应股东玩家 考虑Switch回溯游玩WiiU以及GC游戏
-
今日有任天堂的忠实小股东玩家提议想在Switch玩到WiiU以及GC的经典游戏,官方回应称正在考虑中,敬请期待。·当然,Switch回溯游玩WiiU以及GC游戏的方式有任天堂的在线服务直接游玩官方优...
- Switch 2神秘C键用途曝光!或能连接初代NS手柄
-
直到近日,游戏圈内的风云人物、知名爆料人extas1s站了出来,带来一则令人颇感意外的消息。extas1s爆料称,玩家有望借助这个神秘的C按钮,实现初代Switch与Switch2...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
因果推断Matching方式实现代码 因果推断模型
-
git pull命令使用实例 git pull--rebase
-
git pull 和git fetch 命令分别有什么作用?二者有什么区别?
-
面试官:git pull是哪两个指令的组合?
-
git 执行pull错误如何撤销 git pull fail
-
git fetch 和git pull 的异同 git中fetch和pull的区别
-
git pull 之后本地代码被覆盖 解决方案
-
还可以这样玩?Git基本原理及各种骚操作,涨知识了
-
git命令之pull git.pull
-
- 最近发表
-
- 为什么劝你不要买Switch OLED?(现在买switch oled划算吗)
- 新游戏、怀旧机!没有Switch新机的任天堂还能俘虏玩家们的心吗?丨C位
- 腾讯引进Nintendo Switch (OLED版)开启预售 多重满足您的娱乐需求
- 股东大会上任天堂考虑移植更多WiiU和GC游戏到Switch
- 《野狗子》M站均分低至60分!IGN仅给5分、VGC感觉像是PS3游戏
- 《EA SPORTS FC 25》加入任天堂游戏试玩会,Switch版可免费体验
- Double Kill!马里奥乐园+Switch能解任天堂焦虑吗?丨C位
- 迷你主机、Switch好搭子:16寸4K超亮QLED CFORCE便携屏值得入手吗
- 怎样查看Switch的“主机序列号信息”
- Switch版《EA SPORTS FC 25》容量相比前作缩水
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mysql max (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)