欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

phpStudy中升级MySQL版本到5.7.17的方法步骤

程序员文章站 2024-03-11 16:14:49
前言 今天在工作发现一个错误,在往本地导数据表的时候老是报错: [err] 1294 - invalid on update clause for '字段名'...

前言

今天在工作发现一个错误,在往本地导数据表的时候老是报错:

[err] 1294 - invalid on update clause for '字段名' column

报错的数据表字段:

`字段名` datetime default null on update current_timestamp

同事说同一个 sql 文件他可以导成功。猜可能是数据库版本的问题,同事的是 5.6,我查了下本地的数据库版本是 5.5.53。网上查了一下,果然是版本的问题,5.5 和 5.6 在 timestemp 的行为上有所不同,5.6.5 之前的版本不支持多个current_timestamp 默认值。

由于本地用的集成环境是 phpstudy 2016,没有找到升级 mysql 版本的选项,所以自己升级一下。

从官网上下载高版本的 mysql :

官方网址:

百度云盘地址:https://pan.baidu.com/s/1mi4uhta

选的版本是 5.7.17(后面才发现 5.7 版本的安装、系统表字段等又和之前的版本有所不同)。

步骤:

一、备份原来 phpstudy 中 mysql 安装目录

二、把下载的 mysql 压缩文件解压至 phpstudy 下的 mysql目录,复制 my-default.ini ,重命名为 my.ini。

打开 my.ini,找到 #basedir 处编辑:

basedir=d:/phpstudy/mysql
datadir=d:/phpstudy/mysql/data

三、把 mysql 安装路径添加至系统环境变量

四、在 cmd 下进入 mysql 的 bin 目录(我的是 d:/phpstudy/mysql/bin),执行:

mysqld --initialize

初始化数据库

五、安装服务:

mysqld -install

启动服务:

net start mysql

六、此时登入 mysql 报错:

c:\users\dell>mysql -uroot -p
enter password: ****
error 1045 (28000): access denied for user 'root'@'localhost' (using password: yes)

尝试修改 root 用户密码:

打开 my.ini,找到 [mysqld],在下面添加:

skip-grant-tables

此时使用 root 账号,密码处按回车即可登录。

修改密码:

mysql>update mysql.user set authentication_string=password('new_password') where user='root' and host ='localhost'
mysql> alter user user() identified by 'news_password';

刷新权限:

flush privileges;

注释掉 my.ini 中刚才添加的

skip-grant-tables

重新登录。

此时查看 mysql 版本:

mysql> select version();
+-----------+
| version() |
+-----------+
| 5.7.17  |
+-----------+

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。

参考:

phpstudy升级mysql教程

修改mysql 5.7.9版本的root密码方法以及一些新变化整理