《Disney +》 迪士尼、Marvel、彼思、星球大戰…  任天堂再度聯手日本家居服品牌GELATO PIQUE推出超級瑪利歐系列商品!   IKEA於東京電玩展開店 ! 將在活動聯同ROG推出新電競家具 !   絆愛聯名Fall Guys!還有合作大賽!   12月3日是PlayStation日!4K電視抽獎活動進行中!   歡迎來到《虹彩六號:撤離禁區》的世界   獨立遊戲成為今天曝光及更新亮點   經營遊戲爸爸活公司「CryptoGames 株式會社」宣布將從 Animoca、Monex、Mobile Factory、double jump.tokyo 等四間公司獲得資金援助。   在《決勝時刻:太平洋戰區》第一季即將推出的內容 

MySQL 8.0 新增資料庫帳號(User)

商業

MySQL 8.0 要新增 DB User 的方法跟以前不太一樣,以前只要 grant 就會自動建立,現在需要另外 CREATE。

現在會需要下述步驟:

  1. 建立使用者
  2. 給使用者授權權限

MySQL 8.0 新增資料庫帳號(User)

建立使用者

  • CREATE USER 'username'@'localhost' IDENTIFIED BY 'password'; # 採用 default
  • CREATE USER 'username'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password';
  • 註:現在建議先使用 WITH mysql_native_password

授權使用者權限

  • GRANT SELECT,INSERT,UPDATE,DELETE,CREATE ON db_name.* TO 'username'@'localhost';
  • GRANT ALL PRIVILEGES ON *.* TO 'username'@'localhost';
  • GRANT ALL PRIVILEGES ON db_name.* TO 'username'@'127.0.0.%';

問題排解

若上面建立使用者沒有使用 WITH mysql_native_password,PHP 7.3 PDO 連線遇到下述錯誤:

  • connection failed: SQLSTATE[HY000] [2054] The server requested authentication method unknown to the client
  • PHP 測試:$dbh = new PDO('mysql:host=localhost;dbname=db_name', 'username', 'password');

解法

  • ALTER USER 'username'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password';
Tsung

隨機商業新聞

Micorsoft