MySQL系列:Windows 下 MySQL 8.X 的安裝

  • 2019 年 11 月 14 日
  • 筆記

之前一直使用的是MySQL5.7,但由於MySQL增加了一些新特性,所以選擇了更新。

下載MySQL

進入MySQL官網下載地址,選擇Windows (x86, 64-bit), ZIP Archive。

下載地址:https://dev.mysql.com/downloads/mysql/

可不用登錄,直接跳過。下載過程也許有丟丟慢,耐心等待下。

下載完成後,直接解壓到自己喜歡的位置即可。

卸載原有版本

如果之前有安裝低版本的MySQL,需要先卸載之前的MySQL。如果沒有安裝過,可直接跳過該步驟。

管理員打開cmd,先 net stop mysql 停掉 mysql 服務,然後使用 mysqld remove MySQL 移除MySQL。

net stop mysql  mysqld remove 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_HOME的環境變數指向新版本位置。

安裝MySQL

在MySQL的解壓目錄里,新建data文件夾,並創建my.ini配置文件。

[mysqld]  # 設置3306埠  port=3306  # 設置mysql的安裝目錄  basedir=E:\tools\MySQL\mysql-8.0.18-winx64  # 設置mysql資料庫的數據的存放目錄  datadir=E:\tools\MySQL\mysql-8.0.18-winx64\data  # 允許最大連接數  max_connections=3000  # 允許連接失敗的次數。這是為了防止有人從該主機試圖攻擊資料庫系統  max_connect_errors=10  # 服務端使用的字符集默認為UTF8  character-set-server=utf8  # 創建新表時將使用的默認存儲引擎  default-storage-engine=INNODB    [mysql]  # 設置mysql客戶端默認字符集  default-character-set=utf8    [client]  # 設置mysql客戶端連接服務端時默認使用的埠  port=3306  # 設置mysql客戶端連接服務端時默認字符集  default-character-set=utf8

進入bin目錄,執行mysqld –initialize –console,執行成功會輸出臨時密碼。

mysqld --initialize --console    執行成功後會輸出: A temporary password is generated for root@localhost: a4lcly4e8f-G  a4lcly4e8f-G就是臨時密碼

然後使用該密碼就可以進行了,幸運的話,就可以正常進入MySQL。

登錄報錯

如果不幸地,在使用臨時密碼登錄時報錯,ERROR 1045 (28000):Access denied for user ‘root’@’localhost’ (using password: YES)。

遇到此問題,需要跳過密碼校驗。

先停掉MySQL服務:net stop mysql

在MySQL安裝路徑的bin目錄,輸入mysqld –console –skip-grant-tables –shared-memory,此時cmd窗口會被掛起,也就是看起來卡住一樣,不用擔心,這是正常現象。

然後再打開另一個窗口,同樣是MySQL安裝路徑的bin目錄,直接輸入mysql,在執行use mysql。

使用flush privileges刷新許可權,再alter user’root’@’localhost’ IDENTIFIED BY ‘1234’;更改密碼。

保險起見,再次使用flush privileges刷新許可權。

關閉窗口,使用剛剛的密碼重新連接MySQL:mysql -u root -p,然後再輸入密碼。若顯示服務未啟動,需先啟動MySQL服務,輸入net start mysql。

# 關閉MySQL  net stop mysql    # 跳過許可權校驗  mysqld --console --skip-grant-tables --shared-memory    # 刷新許可權  flush privileges    # --skip-grant-tables模式下連接MySQL  mysql    # 使用系統mysql庫  use mysql    # 更改密碼  alter user 'root'@'localhost' IDENTIFIED BY '1234';    # 刷新許可權  flush privileges    # 連接MySQL,-u、-p後空格可省略,-p後可不輸入密碼,再回車後再鍵入密碼,這樣更安全  mysql -u root -p 1234    # 退出MySQL  q  exit  quit