最近在研究 liferay 的使用。liferay 可以连接 mysql 数据库。电脑中装的 mysql 的最新版本是 mysql8。于是开始按照 liferay 的要求进行连接。但是多番尝试后,均报错:java.sql.SQLException: java.lang.ClassCastException: java.math.BigInteger cannot be cast to java.lang.Long。询问了一下高人,说可能是 mysql 的版本太高,建议降到 mysql5 再尝试连接。于是开始了 mysql 降级之旅。
1、mysql8 卸载
(1) 停 mysql 服务
net stop mysql
(2) 删除 mysql 的安装目录。网上好多教程说要在控制面板中删除,但是我的 win10 系统卸载程序里面根本没找到 mysql 这个软件。就直接先把目录删掉了。(3) 删除注册表里的 mysql 信息网上说要删掉下面 3 个值,但是我只找到一个,就删掉了第一个。打开注册表:方式 1:在终端命令里输入 regedit 方式二:在 c 盘下的 windows 路径下找到 regedit.exe 执行程序 C:Windows 然后将下面三个路径下的 MySQL 相关文件夹删除。
HKEY_LOCAL_MACHINE/SYSTEM/ControlSet001/Services/Eventlog/Application/MySQL
HKEY_LOCAL_MACHINE/SYSTEM/ControlSet002/Services/Eventlog/Application/MySQL
HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/Eventlog/Application/MySQL
补充:完成了上述 MySQL 卸载操作后,在安装新的 MySQL 时,会出现
The vervice already exists!The current server installed: 以前安装 mysql 的地址 /bin/mysqld-nt MYSQL 解决办法:
1、移除原来的 MySQL 服务
mysqld -remove MySQL
2、重新注册 MySQL 服务
mysqld –install MySQL –defaults-file=”C:\mysql-5.1.34\my.ini”
## 2、安装 mysql5 ##(1)下载并解压(2)新建 my.ini
[mysql]
default-character-set=utf8
[mysqld]
port = 3306
basedir=E:\\soft_install\\mysql-5.7.24-winx64
datadir=E:\\soft_install\\mysql-5.7.24-winx64\\data
max_connections=200
character-set-server=utf8
default-storage-engine=INNODB
max_connect_errors=100
explicit_defaults_for_timestamp=true
(3)新建 data 文件夹 (4) 初始化并安装 mysql
mysqld –install mysql –defaults-file=E:\soft_install\mysql-5.7.24-winx64\my.ini
(5)启动
net start mysql
补充:(1)my.ini 的目录要用 \,这个很重要。在安装时,我一直用的是,但是一直报错,改成 \ 就好了。(2)mysql 服务无法启动服务没有报告任何错误解决方案:可以重新进行初始化,重新启动,初始化之前要清空 data 文件夹(跟 bin 同级)还可以删除服务,重新注册 mysqld -remove mysql