MySQL 8.0给开发方向带来的一些困扰

数据库 MySQL
MySQL 8.0的特性可谓强大,有一种集中火力的感觉,从整体的架构设计到功能和参数,可圈可点。

[[346386]]

 MySQL 8.0的特性可谓强大,有一种集中火力的感觉,从整体的架构设计到功能和参数,可圈可点。

不过我今天从开发的角度来说一下困扰,毕竟那么新,那么强大,所谓的无缝,平滑还是需要经过全面测试,不能浮于纸面。

1:密码策略插件

MySQL 8.0开始将caching_sha2_password作为默认的身份验证插件。如果升级了数据库至8.0版本,对应用程序jdbc驱动兼容性不友好,让应用程序跑起来最快的方法需要将默认的caching_sha2_password改为之前的mysql_native_password。

比如:

  1. ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password'

也可以在参数中进行设置,修改my.cnf,重启服务即可生效:

  1. default_authentication_plugin=mysql_native_password 

2.JDBC驱动变更

如果从MySQL5.5升级到5.7,那么驱动的事情不用担心,但是到了8.0,JDBC的驱动就需要格外注意了,否则很可能有如下的错误。

Loading class `com.mysql.jdbc.Driver'. This is deprecated. The new driver class is `com.mysql.cj.jdbc.Driver'. The driver is automatically registered via the SPI and manual loading of the driver class is generally unnecessary.

对于JDBC的url会有如下的变化:

  1. String Url="jdbc:mysql://211.159.xxx:33071/maxwell_test?useUnicode=true&characterEncoding=utf-8"

需要调整为如下的格式:

  1. String Url="jdbc:mysql://211.159.xxx:33071/maxwell_test?useUnicode=true&characterEncoding=utf-8&useSSL=false&&serverTimezone=GMT"

相应的加载驱动程序则需要

  1. Class.forName("com.mysql.jdbc.Driver"); 

修改为:

  1. Class.forName("com.mysql.cj.jdbc.Driver"); 

3.整数类型的长度警告

比如下面的表结构,通过workbench等工具导出来格式都差不多,但是在8.0里面执行的时候会报警。

  1. CREATE TABLE `data_payment_history_test` ( 
  2.   `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增ID'
  3.   `pid` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '用户ID'
  4. 。。。 
  5.   `cdate` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间'
  6.   。。。 
  7.   PRIMARY KEY (`id`), 
  8.   KEY `idx_credit_overdraw_history__pid` (`pid`) 
  9. ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COMMENT='支付记录'

这里主要涉及两个警告,一个是整数类型的长度警告,另外一个是字符集警告,

展开来说,整数类型的长度警告信息为:Integer display width is deprecated and will be removed in a future,意思是int(11)这种写法已经过时了,应该直接写int,bigint

而字符集配置,在MySQL8.0里面默认是utf8mb4,如果我们手工写了utf8类型,会提示:'utf8' is currently an alias for the character set UTF8MB3, but will be an alias for UTF8MB4 in a future release. Please consider using UTF8MB4 in order to be unambiguous.

当然如果你设置的全局字符集是utf8,则无警告的情况字符集仍然为utf8.

4.windows安装版

windows安装版本一直提供的是32位的,这个是个历史遗留问题,如果有些同学为了方便,直接点点点,可能把线上环境部署成32位就尴尬了,oracle的windows版本路子相反,已经很早就直接舍弃了32位的版本。

本文转载自微信公众号「杨建荣的学习笔记」,可以通过以下二维码关注。转载本文请联系杨建荣的学习笔记公众号。

 

责任编辑:武晓燕 来源: 杨建荣的学习笔记
相关推荐

2017-11-29 18:52:13

Python新手编码建议

2013-07-29 09:36:05

100G传输100G

2023-11-10 08:48:09

Lombok库Java8

2016-11-11 20:33:53

Hadoop大数据云计算

2021-06-08 06:13:16

React开发开发技术

2009-07-09 13:16:54

Java Swing开

2021-12-15 11:30:04

无人驾驶智能技术

2011-11-28 15:57:26

MySQL数据库主从配置

2013-04-28 09:44:44

2021-06-30 07:19:35

微服务业务MySQL

2018-06-21 15:23:36

2015-08-27 10:49:43

JavaScript开发框架

2010-11-02 14:11:15

SilverlightWPF微软开发

2015-07-28 14:39:02

IOS技巧

2018-02-06 11:10:27

iOS开发Xcode快捷键

2009-12-30 15:18:32

2017-10-16 14:40:50

数据库MySQL工具

2011-10-11 17:10:35

MySQL

2018-02-04 22:29:21

iOS开发

2010-05-25 17:00:04

Java WebWeb容器Web应用
点赞
收藏

51CTO技术栈公众号