MySQL 升级方法指南大全

很文博客
很文博客
管理员
11310
文章
0
粉丝
数据库评论838字数 5842阅读模式
广告也精彩

升级授权表之前一定要备份好 mysql 数据库,以备升级失败时使用旧的授权表。

在unix或类unix系统中,运行 mysql_fix_privilege_tables 脚本来升级授权表:文章源自很文博客https://www.zhenjiekeji.com/很文博客-https://www.zhenjiekeji.com/61219.html

shell> mysql_fix_privilege_tables  必须在 mysqld 运行着的时候执行这个脚本,它尝试使用 root 帐号来连接服务器;因此,当 root 需要密码时,用如下方式来指定密码:文章源自很文博客https://www.zhenjiekeji.com/很文博客-https://www.zhenjiekeji.com/61219.html

shell> mysql_fix_privilege_tables --password=root_password  在 MySQL 4.1之前,则是用如下形式来指定密码:文章源自很文博客https://www.zhenjiekeji.com/很文博客-https://www.zhenjiekeji.com/61219.html

shell> mysql_fix_privilege_tables root_password
接下来 mysql_fix_privilege_tables 脚本会升级授权表,在这个过程中可能会有一些 Duplicate column name 警告信息,无需理会它们。待它运行完之后,重启一下服务器即可。文章源自很文博客https://www.zhenjiekeji.com/很文博客-https://www.zhenjiekeji.com/61219.html

在windows平台上,授权表想要升级到4.0.15并不容易。从4.0.15开始,发行版中包含一个sql脚本:mysql_fix_privilege_tables.sql,用 mysql 客户端运行它来升级授权表,运行类似如下命令:文章源自很文博客https://www.zhenjiekeji.com/很文博客-https://www.zhenjiekeji.com/61219.html

C:\> C:\mysql\bin\mysql -u root -p mysql
mysql> SOURCE C:/mysql/scripts/mysql_fix_privilege_tables.sql
把上面提到的目录改成真实的目录。文章源自很文博客https://www.zhenjiekeji.com/很文博客-https://www.zhenjiekeji.com/61219.html

3、) 升级同步文章源自很文博客https://www.zhenjiekeji.com/很文博客-https://www.zhenjiekeji.com/61219.html

请查看我翻译的文档"6.6 升级同步"

4、) mysql_update MySQL升级时检查数据表

每次升级的时候都必须运行 mysql_upgrade 脚本。它检查了当前版本的MySQL下的所有数据库表的不兼容性,就会检查这些表;并且发现有问题时,也会修复这些表。mysql_update 同时升级了系统表,因此可以兼容新的权限机制并且使用新增的权限。

由于 mysql_update 会把检查过和修复过的表都标记上当前的MySQL版本号,因而保证了下一次在同一个MySQL版本下运行这个脚本时,都会再次报告哪些表需要修复或检查。

它还会把MySQL的版本号记录在数据文件目录下的一个文件中:mysql_upgrade.info。这个文件用于标识当前发布版本检查表时哪些表可以略过,检查时想要忽略这个文件,只需附加上 --force 选项。

为了能检查和修复数据表,并且升级系统表,mysql_update 执行了一下命令:

mysqlcheck --check-upgrade --all-databases --auto-repair
mysql_fix_privilege_tables
mysql_update 目前只支持类unix平台;在windows下,需要手工执行 mysqlcheck 命令,升级授权表请看附录"升级授权表"。

执行 mysql_update 时,MySQL服务器必须运行着,它有以下几个参数:

--help
显示帮助信息并且退出

--basedir=path
设定MySQL的安装路径

--datadir=path
设定MySQL的数据文件路径

--force
告诉 mysql_update,在检查时忽略是否存在 mysql_upgrade.info 文件,强行检查该版本的MySQL数据表,不管是否已经检查过了

--user=user_name, -u user_name
连接到MySQL的用户名,默认是 root

--verbose
冗余模式。发生问题时打印出更多的信息

其他的选项诸如 --password[=password] 是要传递给 mysqlcheck 和 mysql_fix_privilege_tables 脚本的,并不是必须的。

工具:作品在线观看

女优:最新作品观看

中文:国语在线观看

weinxin
我的微信
微信号已复制
扫一扫更精彩
大家的支持是我更新的动力!!!
 
广告也精彩
匿名

发表评论

匿名网友
:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:
确定

拖动滑块以完成验证