」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > MySQL 終端機:登入、使用者和權限

MySQL 終端機:登入、使用者和權限

發佈於2024-11-02
瀏覽:594

MySQL Terminal: Login, Users and Permissions

存取MySQL

sudo mysql -u root -p 

sudo mysql -u root -p 指令用於以具有管理權限的 root 使用者身分存取 MySQL。運行命令後,會提示輸入MySQL root用戶密碼。

  • sudo:以超級使用者權限執行指令。
  • mysql: 啟動 MySQL 用戶端。
  • -u root:指定您以「root」使用者身分連線。
  • -p:請求MySQL詢問指定使用者的密碼。

如果沒有為MySQL root使用者設定密碼,指令可能會失敗。如果是這種情況,您可以設定密碼或不使用 -p(無密碼)選項存取 MySQL。

建立一個新用戶

SQL CREATE USER 指令用於在 MySQL 中使用使用者名稱和密碼建立新使用者。

CREATE USER 'username'@'localhost' IDENTIFIED BY 'password';
  • 使用者名稱:您正在建立的新使用者的名稱。
  • localhost:指定使用者只能從執行 MySQL 的伺服器連線到 MySQL。如果要允許遠端連接,可以將 localhost 替換為 % 或特定的 IP 位址。
  • 密碼:將與該使用者關聯的密碼。

建立使用者後,需要為其授予權限。

授予使用者權限

  • 授予資料庫的所有權限

如果要授予特定資料庫的所有權限,請使用:

GRANT ALL PRIVILEGES ON database_name.* TO 'user_name'@'localhost';
  • 特定權限

也可以指定權限,如SELECT、INSERT、UPDATE、DELETE等

GRANT permission ON database_name.* TO 'user_name'@'localhost';
  • 特定表的權限

僅授予特定表格的權限

GRANT ALL PRIVILEGES ON database_name.table_name TO 'user_name'@'localhost';
  • 授予全域權限

授予所有資料庫的權限

GRANT ALL PRIVILEGES ON *.* TO 'user_name'@'localhost';
  • 允許使用者授予其他使用者權限
GRANT ALL PRIVILEGES ON *.* TO 'user_name'@'localhost' WITH GRANT OPTION;

更新權限

FLUSH PRIVILEGES 指令用於在 MySQL 中重新載入權限表,使您對使用者權限所做的變更生效,無論是使用 GRANT、REVOKE 或 CREATE USER 指令。

FLUSH PRIVILEGES;

檢查權限

SHOW GRANTS FOR 'username'@'localhost';

SHOW GRANTS FOR username'@'localhost;指令顯示與 MySQL 中指定使用者關聯的權限。它對於檢查使用者對資料庫擁有的權限很有用。

撤銷權限

REVOKE指令用於刪除MySQL中使用者的特定權限。

REVOKE ALL PRIVILEGES ON database_name.* FROM 'user_name'@'localhost';
  • 撤銷權限後,使用者仍然存在,但在指定資料庫中沒有權限。
  • 建議在撤銷權限後執行 FLUSH PRIVILEGES 命令,以確保變更立即套用。

列出用戶

SELECT User, Host FROM mysql.user;

SELECT User, Host FROM mysql.user;指令用於查詢MySQL中的mysql.user表,該表儲存了系統中建立的所有使用者的資訊。

了解哪個用戶已連接

SELECT USER();

選擇使用者(); MySQL 中的指令傳回您在目前工作階段中使用的使用者名稱和主機名稱。它是一個顯示使用哪個使用者帳號連接到資料庫的函數,格式為 user@host.

版本聲明 本文轉載於:https://dev.to/xxzeroxx/mysql-terminal-login-users-and-permissions-53ie?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 為什麼我在 POST Jersey 請求中收到不支援的媒體類型錯誤?
    為什麼我在 POST Jersey 請求中收到不支援的媒體類型錯誤?
    POST Jersey 請求中不支援的媒體類型錯誤遇到HTTP 狀態代碼415 - 對Jersey 的POST 請求中不支持的媒體類型REST 服務,問題通常在於Jersey 發行版中缺少JSON/POJO 支援。要解決此錯誤,需要在專案中新增必要的 JAR 依賴項。 具體來說,需要以下依賴:jer...
    程式設計 發佈於2024-11-07
  • 針對 XSS 的常見防禦措施有哪些?
    針對 XSS 的常見防禦措施有哪些?
    針對 XSS 的常見防禦輸入和輸出清理是防止跨站腳本 (XSS) 攻擊的關鍵技術。本文探討了產業和個人網站廣泛採用的減輕這種威脅的方法。 1。 HTML 轉義:在將所有使用者輸入顯示為 HTML 程式碼之前徹底轉義它們。這涉及將“”、“&”和“等字元替換為其相應的HTML 實體(例如,“”、“&”、...
    程式設計 發佈於2024-11-07
  • Python垃圾收集器如何自動管理記憶體?
    Python垃圾收集器如何自動管理記憶體?
    Python 垃圾收集器文件Python 垃圾收集器是一個記憶體管理系統,可以自動釋放程式不再使用的記憶體。這有助於透過防止記憶體洩漏並確保程式不會耗盡記憶體來提高效能。 垃圾收集器的工作過程分為兩步:引用計數: 解釋器追蹤每個物件的引用數量。當引用計數達到零時,該物件被認為不可達,並添加到要刪除的...
    程式設計 發佈於2024-11-07
  • PHP 如何有效率地處理大整數?
    PHP 如何有效率地處理大整數?
    PHP 可以處理大整數嗎? PHP 可能沒有明確的「BigInteger」類,但它提供了幾種處理大整數的方法整數。 使用 BC 數學函數PHP 提供BC 數學函數,如用於整數算術的 bcadd() 和 bcsub()。然而,這種方法對於大量計算來說可能會很慢。 使用 GMP 擴展GMP(GNU 多精...
    程式設計 發佈於2024-11-07
  • 如何使用 Python 字串匹配驗證 IP 位址輸入?
    如何使用 Python 字串匹配驗證 IP 位址輸入?
    使用 Python 驗證 IP 位址輸入驗證使用者輸入的 IP 位址在各種應用中至關重要。本文將探討驗證以字串形式提供的 IP 位址合法性的最有效方法。 首選方法偏離解析,而是利用 Python 標準函式庫的套接字模組。透過利用 inet_aton(),我們可以確定輸入字串是否代表有效的 IP 位址...
    程式設計 發佈於2024-11-07
  • 那麼 Pull 請求如何再次發揮作用呢?螢幕顯示#3
    那麼 Pull 請求如何再次發揮作用呢?螢幕顯示#3
    在我之前的文章中,我談到了啟動一個基於開源 GenAI 的終端應用程式。本週的任務是為另一個用戶的專案貢獻一個新功能。由於我們必須與新人合作,所以我與 Lily 合作,她開發了一個應用程序,其代碼改進功能與我的類似,只是她的角色是老鼠! 有時間的話可以去看看她的專案老鼠助手。 她的程式碼是用 T...
    程式設計 發佈於2024-11-07
  • 為什麼 Go 中不能直接將 []string 轉換為 []interface{}?
    為什麼 Go 中不能直接將 []string 轉換為 []interface{}?
    為什麼將[]string 轉換為[]interface{} 會在Go 中引發編譯錯誤轉換字串切片([] string)考慮到它們共享切片特徵以及[]string 的每個元素都可以被視為一個接口,Go 中的接口切片([]interface{}) 似乎很簡單。然而,嘗試這種轉換時會出現編譯錯誤,讓程式設...
    程式設計 發佈於2024-11-07
  • 理解 Shadow DOM:封裝 Web 元件的關鍵
    理解 Shadow DOM:封裝 Web 元件的關鍵
    在現代 Web 開發中,創建可重複使用和可維護的元件至關重要。 Shadow DOM 是 Web 元件標準的一部分,在實現這一目標方面發揮著至關重要的作用。本文深入探討了 Shadow DOM 的概念、它的優點以及如何在您的專案中有效地使用它。 什麼是 Shadow DOM? Sh...
    程式設計 發佈於2024-11-07
  • 如何使用 Java 運行時解決輸出重定向問題?
    如何使用 Java 運行時解決輸出重定向問題?
    使用Runtime 的exec() 方法解決輸出重定向問題在Java 中,利用Runtime.getRuntime().exec() 運行指令可以擷取進程的輸出和錯誤流。但是,在需要輸出重定向的情況下,單獨使用此方法可能會無效。 問題:輸出未重定向當使用Runtime.getRuntime().ex...
    程式設計 發佈於2024-11-07
  • 如何使用 CSS 懸停效果從左到右填滿背景顏色?
    如何使用 CSS 懸停效果從左到右填滿背景顏色?
    使用CSS 從左到右填充背景顏色在CSS 中,您可以透過利用線性漸層和動畫背景定位來創造迷人的懸停效果。這種方法使您能夠在懸停時從左到右用新顏色填充元素的背景。 線性漸變和背景大小關鍵是使用由兩種顏色組成的線性漸變背景,並將背景大小設定為元素寬度的兩倍。這允許您在兩種顏色之間創建無縫過渡。 背景定位...
    程式設計 發佈於2024-11-07
  • GraalVM 本機映像中的記憶體管理
    GraalVM 本機映像中的記憶體管理
    内存管理是计算机软件开发的重要组成部分,负责应用程序中内存的有效分配、利用和释放。其重要性在于增强软件性能,保证系统稳定性。 垃圾收集 垃圾收集 (GC) 在 Java 和 Go 等当代编程语言中至关重要。它自动检测并回收未使用的内存,从而减轻开发人员手动管理内存的需要。 GC 的概...
    程式設計 發佈於2024-11-07
  • ## 在 C++ 中什麼時候應該使用參考作為函數參數?
    ## 在 C++ 中什麼時候應該使用參考作為函數參數?
    在 C 中傳遞參數:瞭解引用在 C 中,函數參數的行為由其型別決定。一個重要的區別是「按值傳遞」和「按引用傳遞」。 為什麼在函數參數中使用引用? 引用在函數參數中用於兩種情況主要原因:修改參數:引用允許函數修改值論證通過了。這意味著該函數可以進行呼叫者可見的更改。 避免物件複製: 透過引用傳遞大物件...
    程式設計 發佈於2024-11-07
  • 為什麼會出現“getaddrinfo 失敗”以及如何修復?
    為什麼會出現“getaddrinfo 失敗”以及如何修復?
    探索“getaddrinfo failed”錯誤名稱解析過程中發生錯誤“getaddrinfo failed”,其中主機名稱被翻譯轉換為IP 位址。它顯示所提供的主機名的解析有問題。 深入研究錯誤情境從提供的錯誤追蹤中,我們可以將原因追溯到套接字。 getaddrinfo(主機,連接埠)方法。當無法...
    程式設計 發佈於2024-11-07
  • 如何在單一命令列中運行多行命令?
    如何在單一命令列中運行多行命令?
    如何在一行命令列中執行多行語句使用Python的-c選項執行單行循環時,在循環之前導入模組會導致語法錯誤。這是因為Python解釋器將程式碼區塊視為單一語句。 要解決此問題,可以採用以下幾種方法:使用管道要克服語法錯誤,請使用echo 命令將程式碼區塊作為一系列輸入行重定向到Python:echo ...
    程式設計 發佈於2024-11-07
  • 如何在 PHP 中從 MySQL 遷移到 MySQLi?
    如何在 PHP 中從 MySQL 遷移到 MySQLi?
    從 MySQL 遷移到 MySQLi將網站從 MySQL 遷移到 MySQLi 需要修改 PHP 程式碼,但資料庫本身基本上不受影響。 MySQLi 是 MySQL 擴充功能的改進版本,提供增強的功能和安全性。 PHP 程式碼變更是的,您可以簡單地將 MySQLi 函數替換為 MySQL 函數。這裡...
    程式設計 發佈於2024-11-07

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3