1. 程式人生 > >django2.0連結MYSQL 8.0的root更改密碼問題.。出現的(1045, (using password:NO))玩死我

django2.0連結MYSQL 8.0的root更改密碼問題.。出現的(1045, (using password:NO))玩死我

非常感謝這篇文章救了弄了一個下午的我,https://blog.csdn.net/M_C_ing/article/details/80412165

環境是WIN10的64位,MYSQL8.0, Django2.0.3

錯誤1: django.db.utils.OperationalError: (1045, "Access denied for user 'root'@'localhost' (using password: NO)")

本人在django連結mysql時,出現以下問題

檢查密碼並嘗試使用mysql -u root -p命令登入,沒問題。但使用mysql -u root也出現這個錯誤。

原因是。MYSQL8.0對比之前的版本, 的加密方式變了,所以需要用舊的方式加密, 更改密碼。

解決方法如下, 其中newpassword是自己設定的新密碼

mysql -u root -p
use mysql;
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'newpassword';  
FLUSH PRIVILEGES;  

 

錯誤2:django.db.utils.OperationalError: (1045, "Access denied for user 'root'@'localhost' (using password: YES)")

這個錯誤是密碼錯誤的問題。如忘記密碼請更改密碼。具體請自行百度,不搬運。

如果是django的,請檢查賬號密碼是否匹配,比如我的是這樣的。django連結MYSQL就需要改下面兩項而已。檢查一下就行

檢查setting檔案裡的程式碼。也沒有問題。


DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'HOST': 'localhost',
        'POST': '3306',
        'NAME': 'guest',
        'USER': 'root',
        'PASSWORD': "123456",
        'OPTIONS':{'init_command': "SET sql_mode='STRICT_TRANS_TABLES'",},
        #'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

__init__檔案的程式碼

import pymysql
pymysql.install_as_MySQLdb()

錯誤3:如果你沒有設定root密碼

那麼直接命令列執行mysql命令