mysql当前日期减一天(mysql8.0和5.7区别)

在这些年的MySQL升级需求中,让我大跌眼镜的一个现象是:驱动业务从MySQL 5.5升级到MySQL 5.7的很大一个因素是因为JSON这个特性

而让业务有所顾虑从MySQL 5.7升级到MySQL 8.0的一个主要原因是:驱动版本升级,所以对于MySQL 5.7升级到MySQL 8.0来说,总体的升级动力明显要低一些,但是规划的一个优点就是可以把一些工作前置,或者让它的推行更加顺畅,比如我们对于新业务的推行,都是默认按照MySQL 8.0的方案来做。

mysql当前日期减一天(mysql8.0和5.7区别)

如果要说MySQL 5.7升级到MySQL 8.0的一些差异,从我的角度来说,其实变化是很大的,但是细数盘点,很多特性似乎是对于业务的一种友好或者透明支持。

细节1:

比如我们在MySQL 5.7版本中全面推行GTID,所以之前的create table xxx as select * from xx的使用模式就不奏效了,进而我们建议使用:

create table xxx like xxxxx;

insert into xxx select * from xxxxx;

这种使用模式,而MySQL8.0带来的很多特性是在体验和性能改造方面,原来不建议使用的模式竟然可以支持了,而很多业务侧是后知后觉,原本已经培养的习惯,让我们有些凌乱。

细节2:

在MySQL 5.7中字段名为rank是可以的,但是在8.0中因为有了窗口函数,字段名为rank就报错,顺着这个思路,其实我们一窥窗口函数。

mysql当前日期减一天(mysql8.0和5.7区别)

其实就会发现不光是rank,字段名是first_value也不可以了,随之带来的就是SQL语法错误,可能会让人开始有点抓不着头脑。

create table test3(id int primary key,first_value varchar(30));

ERROR 1064 (42000): 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 ‘first_value varchar(30))’ at line 1

 

细节3:

这里顺便吐槽下airflow的表结构配置

airflow的一个表结构在MySQL 5.7中如下:

CREATE TABLE kube_resource_version(one_row_id BOOL NOT NULL DEFAULT true, resource_version VARCHAR(255),PRIMARY KEY (one_row_id),CONSTRAINT kube_resource_version_one_row_id CHECK (one_row_id),CHECK (one_row_id IN (0, 1)));Query OK, 0 rows affected (0.06 sec)

在MySQL中其实会被默认转换为如下的表结构:

CREATE TABLE `kube_resource_version` ( `one_row_id` tinyint(1) NOT NULL DEFAULT ‘1’, `resource_version` varchar(255) DEFAULT NULL, PRIMARY KEY (`one_row_id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;

如果查看在线业务的实际数据如下:

mysql> select * from kube_resource_version;+————+——————+| one_row_id | resource_version |+————+——————+| 1 | |+————+——————+1 row in set (0.01 sec)

看起来这个boolean类型真是有些鸡肋,在数据库中已经默认使用tinyint(1)来间接转义了,但是实际上还是不对味。

带来的问题是在MySQL 5.7中可以成功创建,但是在8.0会报错:

CREATE TABLE kube_resource_version (one_row_id BOOL NOT NULL DEFAULT true, resource_version VARCHAR(255), PRIMARY KEY (one_row_id), CONSTRAINT kube_resource_version_one_row_id CHECK (one_row_id), CHECK (one_row_id IN (0, 1)));ERROR 3812 (HY000): An expression of non-boolean type specified to a check constraint ‘kube_resource_version_one_row_id’.

而经过分析,其实8.0的报错提示更加合理,至少我觉得8.0对于数据层面的要求确实变高了。

 

细节4:

在MySQL里面如果对一张大表做delete,真是一件让人尴尬的事情,在MySQL 5.7里面有点后知后觉,在show processlist的输出中。State和Info列分别显示:

Executing event 和delete from xxxxx

同时Seconds_Behind_Master显示为0,实际上数据已经产生大量延迟了。

而相反在MySQL 8.0里面,State和Info列分别显示:

Applying batch of row changes (delete)和delete from xxxxx

可以明确的提示出批量操作,当然这延迟确实不体面,真是非常大。

 

简单小结:MySQL 8.0里面的很多细节还是很接地气,也不能潜意识的认为是100%兼容,要拍胸脯保证的事情,得有深入的测试和案例分析支撑。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至2705686032@qq.com 举报,一经查实,本站将立刻删除。原文转载: 原文出处:

(0)
尊云-小张的头像尊云-小张
上一篇 2024 年 5 月 11 日 09:30
下一篇 2024 年 5 月 11 日 09:35

相关推荐

  • wordpress是什么语言编写的

    WordPress是使用PHP语言编写的开源内容管理系统(Content Management System,简称CMS)。PHP是一种流行的服务器端脚本语言,专门用于开发Web应用程序。WordPress还使用了HTML、CSS和JavaScript等前端技术来呈现网页内容,并通过MySQL数据库存储数据。 WordPress的核心框架和功能是基于PHP编…

    2024 年 4 月 22 日
    000
  • vi和vim有什么区别(vi设计包括什么)

    它是一个老式的文字处理工具,但是功能很齐全,不仅是文本处理工具,还是一个程序编辑工具,就连官方网站也说vim是一个程序开发工具而不是文字处理软件,因为它包含了很多额外的功能,如:多文件编辑,区块复制等,这些功能让我们在进行配置文件修改的时候会更方便。今天就来一起学习一下vi和vim。 什么是 vim? Vim 是从 vi 发展出来的一个文本编辑器。代码补全、…

    2024 年 4 月 20 日
    000
  • 开启mysql服务命令是什么(启动数据库服务命令)

    mysql服务启动和关闭的方法: 一、通过【计算机管理】界面来启动和关闭mysql服务 1、鼠标移动到计算机,点击鼠标右键,选择“管理”。 2、在【计算机管理】界面中选择【服务与应用程序】下的【服务】。 3、服务默认是按字母排序的,所以往下拉,找到M开头的mysql服务。 此时你可以查看它是否已经启动,它是自动启动还是手动。 3、当你点击鼠标左键,选中mys…

    2024 年 5 月 13 日
    000
  • freehostia怎么配置伪静态

    要在Freehostia上配置伪静态,您需要遵循以下步骤: 1. 登录到您的Freehostia帐户并进入控制面板。2. 在控制面板中,找到并点击”网站管理工具”选项。3. 在网站管理工具中,找到并点击”文件管理器”选项。4. 导航到您想配置伪静态的网站的根文件夹。通常,该文件夹的名称是”publi…

    2024 年 4 月 28 日
    000
  • 浏览器被劫持了怎么解决(浏览器主页被劫持原因)

    如何恢复edge浏览器默认主页,有很多朋友问我自己的edge浏览器主页被劫持,一打开不是系统默认的页面,不是什么123就是什么60什么度的,各自喜欢的打卡的主页不一样,想根据自己的爱好设置自己喜欢的主页,可是就是设置不成功,或者是设置的时候直接提示此设置由你的组织管理的修改方法在下面视频里面。 首先来说一下如何自定义设置edge浏览器主页,我们首先打卡edg…

    2024 年 5 月 13 日
    000

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-900-3935

在线咨询: QQ交谈

邮件:cong@zun.com

工作时间:365天无休服务 24小时在线

添加微信