Files
Obsidian-Main/03. Programming/DB/MySQL.md
Awin Huang c847c7f07d vault backup: 2022-09-28 19:13:41
Affected files:
.obsidian/workspace
03. Programming/COM/20210726 - COM Interface.md
03. Programming/DB/MySQL.md
03. Programming/DB/sqlite.md
03. Programming/Design Pattern.md
03. Programming/FFMPEG/00. Introduction.md
03. Programming/FFMPEG/01. Setup.md
03. Programming/FFMPEG/FFMpeg.md
03. Programming/Flask.md
03. Programming/Media Foundation/20210604 - Windows media foundation.md
03. Programming/OpenCV.md
03. Programming/OpenGL.md
03. Programming/Python/argparse.ArgumentParser.md
03. Programming/Python/decorator.md
03. Programming/Python/logging.md
03. Programming/Python/opencv.md
03. Programming/Python/subprocess.md
03. Programming/Python/threading.md
03. Programming/Python/tkinter.md
03. Programming/Python/檢測工具.md
03. Programming/QT/Dropdown button.md
03. Programming/QT/QVariant.md
03. Programming/QT/Qt.md
03. Programming/UML.md
03. Programming/演算法.md
04. 資料收集/99. templates/blogHeader.md
04. 資料收集/99. templates/date.md
04. 資料收集/99. templates/front matter.md
04. 資料收集/99. templates/note.md
04. 資料收集/99. templates/table.md
04. 資料收集/99. templates/thisWeek.md
04. 資料收集/99. templates/日記.md
04. 資料收集/99. templates/讀書筆記.md
04. 資料收集/Linux/CLI/cut.md
04. 資料收集/Linux/CLI/scp.md
04. 資料收集/Linux/CLI/timedatectl.md
04. 資料收集/Linux/Programming.md
04. 資料收集/Linux/Ubuntu.md
04. 資料收集/Tool Setup/Hardware/RaspberryPi.md
04. 資料收集/Tool Setup/Software/Chrome.md
04. 資料收集/Tool Setup/Software/Obisidian.md
04. 資料收集/Tool Setup/Software/SublimeText.md
04. 資料收集/Tool Setup/Software/VirtualBox.md
04. 資料收集/Tool Setup/Software/Visual Studio Code.md
04. 資料收集/Tool Setup/Software/Windows Setup.md
04. 資料收集/Tool Setup/Software/Windows Terminal.md
04. 資料收集/Tool Setup/Software/freefilesync.md
04. 資料收集/Tool Setup/Software/vim.md
04. 資料收集/名言佳句.md
04. 資料收集/架站/Gitea.md
04. 資料收集/架站/HTTP Server/Apache.md
04. 資料收集/架站/HTTP Server/Nginx/Reverse Proxy(Layer4).md
04. 資料收集/架站/Pelican blog.md
04. 資料收集/架站/Proxmox VE.md
04. 資料收集/架站/SWAG Reverse proxy.md
04. 資料收集/架站/Storj.md
04. 資料收集/架站/Trojan.md
04. 資料收集/每週外食.md
04. 資料收集/科技/802.11.md
04. 資料收集/科技/HDR Sensor.md
04. 資料收集/科技/量子電腦.md
04. 資料收集/科技/鋰電池.md
04. 資料收集/興趣嗜好/RC/Traxxas Sledge.md
04. 資料收集/興趣嗜好/RC/好盈電變調整中立點.md
04. 資料收集/興趣嗜好/RC/差速器調教教學.md
04. 資料收集/興趣嗜好/模型/舊化作例.md
04. 資料收集/興趣嗜好/軍武/虎式.md
04. 資料收集/讀書筆記/20201201 - 學習如何學習.md
04. 資料收集/讀書筆記/20201218 - Kotlin權威2.0.md
04. 資料收集/讀書筆記/20201224 - 寫作是最好的自我投資.md
04. 資料收集/讀書筆記/20210119 - 中產悲歌.md
04. 資料收集/讀書筆記/20210220 - 最高學習法.md
04. 資料收集/讀書筆記/20210320 - 最高學以致用法.md
04. 資料收集/讀書筆記/20210406 - 精準購買.md
04. 資料收集/讀書筆記/20210723 - 高手學習.md
04. 資料收集/讀書筆記/20220526 - 深入淺出設計模式.md
04. 資料收集/讀書筆記/20220619 - 精確的力量.md
04. 資料收集/軟體工具/IPFS.md
04. 資料收集/軟體工具/MkDocs.md
04. 資料收集/軟體工具/Obsidian.md
04. 資料收集/軟體工具/docker.md
04. 資料收集/軟體工具/git/apply.md
04. 資料收集/軟體工具/git/submodule.md
04. 資料收集/軟體工具/youtube-dl.md
04. 資料收集/面試準備/技术面试最后反问面试官的话.md
2022-09-28 19:13:41 +08:00

3.9 KiB
Raw Blame History

Install MySQL

Install MariaDB

  1. sudo apt install mariadb-server
  2. Configuring MariaDB: sudo mysql_secure_installation 這步驟會問幾個問題,大概是: 1. 輸入目前root的密碼 2. 是否要切換為unix_socket -> No 3. 要變更root的密碼嗎-> No
  3. Testing MariaDB: sudo systemctl status mariadb
  4. Show version: sudo mysqladmin version

Syntax

Basic

login as root: mysql -u root -p

User management

Create user

CREATE USER 'testuser'@'localhost' IDENTIFIED BY 'test123test!';

Remove user

DROP USER 'testuser'@'localhost';

Grant user's permission

Below commands grant user's permission to CREATE and DROP.

GRANT CREATE ON *.* TO 'testuser'@'localhost';
GRANT DROP ON tutorial_database.* TO 'testuser'@'localhost';
FLUSH PRIVILEGES;

Remove user's permission

REVOKE <permission> ON database.table FROM 'user'@'localhost';

上面命令中的<permission>必須替換成下面的其中一個:

  • ALL - Allow complete access to a specific database. If a database is not specified, then allow complete access to the entirety of MySQL.
  • CREATE - Allow a user to create databases and tables.
  • DELETE - Allow a user to delete rows from a table.
  • DROP - Allow a user to drop databases and tables.
  • EXECUTE - Allow a user to execute stored routines.
  • GRANT OPTION - Allow a user to grant or remove another user's privileges.
  • INSERT - Allow a user to insert rows from a table.
  • SELECT - Allow a user to select data from a database.
  • SHOW DATABASES- Allow a user to view a list of all databases.
  • UPDATE - Allow a user to update rows in a table.

例如:REVOKE CREATE ON *.* FROM 'testuser'@'localhost'; 最後,不要忘記FLUSH PRIVILEGES;

Show user's permission

SHOW GRANTS FOR 'testuser'@'localhost';

Change user's password

ALTER USER 'user-name'@'localhost' IDENTIFIED BY 'NEW_USER_PASSWORD';

View all users

SELECT User,Host FROM mysql.user;

Database

Show all databases

SHOW DATABASES;

Create table

The rule:

CREATE TABLE table_name (column_name column_type);

Example:

CREATE TABLE tutorials_tbl(
   tutorial_id INT NOT NULL AUTO_INCREMENT,
   tutorial_title VARCHAR(100) NOT NULL,
   tutorial_author VARCHAR(40) NOT NULL,
   submission_date DATE,
   PRIMARY KEY ( tutorial_id )
);
use autostation;
CREATE TABLE station_state(
   id CHAR(255) NOT NULL,
   ip CHAR(255) NOT NULL,
   dhcp_ip CHAR(255) NOT NULL,
   name CHAR(255) NOT NULL,
   setupfilemd5 CHAR(255) NOT NULL,
   setupfileversion CHAR(255) NOT NULL,
   status CHAR(255) NOT NULL,
   update_time DATETIME NOT NULL,
   PRIMARY KEY ( id )
);

Insert

The rule:

INSERT INTO <table_name> ( field1, field2,...fieldN )
                         VALUES
                         ( value1, value2,...valueN );

Example:

INSERT INTO client_state ( field1, field2,...fieldN )
                         VALUES
                         ( value1, value2,...valueN );

參考

- Create a MySQL User on Linux via Command Line | Liquid Web - Grant Permissions to a MySQL User on Linux via Command Line | Liquid Web - Remove Permissions for a MySQL User on Linux via Command Line - Liquid Web - Remove a MySQL User on Linux via Command Line - Liquid Web