美文网首页
MySQL命令(一)

MySQL命令(一)

作者: 诺之林 | 来源:发表于2018-08-29 13:08 被阅读9次

目录

概览

SQL Commands

DDL

  • DDL(Data definition language): it is used to define data structures

CREATE

CREATE TABLE employees_2 (
    emp_no      INT             NOT NULL,
    birth_date  DATE            NOT NULL,
    first_name  VARCHAR(14)     NOT NULL,
    last_name   VARCHAR(16)     NOT NULL,
    gender      ENUM ('M','F')  NOT NULL,    
    hire_date   DATE            NOT NULL,
    PRIMARY KEY (emp_no)
);

DESC employees_2;

ALTER

ALTER TABLE employees_2 ADD a TINYINT NOT NULL;

ALTER TABLE employees_2 MODIFY a INT NOT NULL;

ALTER TABLE employees_2 DROP a;

TRUNCATE

TRUNCATE TABLE employees_2;

DROP

DROP TABLE employees_2;

DML

  • DML(Data Manipulation Language): it is used to manipulate data itself

INSERT

INSERT INTO employees VALUES (500000,'1958-05-01','Test','Tsukuda','M','1997-11-30');

SELECT

SELECT * FROM employees ORDER BY emp_no desc LIMIT 1;
+--------+------------+------------+-----------+--------+------------+
| emp_no | birth_date | first_name | last_name | gender | hire_date  |
+--------+------------+------------+-----------+--------+------------+
| 500000 | 1958-05-01 | Test       | Tsukuda   | M      | 1997-11-30 |
+--------+------------+------------+-----------+--------+------------+

UPDATE

UPDATE employees SET last_name = 'Test' WHERE first_name = 'Test'

DELETE

DELETE FROM employees WHERE first_name = 'Test'

SELECT * FROM employees ORDER BY emp_no desc LIMIT 1;
+--------+------------+------------+-----------+--------+------------+
| emp_no | birth_date | first_name | last_name | gender | hire_date  |
+--------+------------+------------+-----------+--------+------------+
| 499999 | 1958-05-01 | Sachin     | Tsukuda   | M      | 1997-11-30 |
+--------+------------+------------+-----------+--------+------------+

DCL

  • DCL(Data Control Language): it is used to control access to data stored in a database (Authorization)

GRANT

GRANT SELECT ON employees.* TO guest@localhost IDENTIFIED BY '123456';
mycli -uguest -p123456

USE employees;

SELECT * FROM employees ORDER BY emp_no desc LIMIT 1;
+--------+------------+------------+-----------+--------+------------+
| emp_no | birth_date | first_name | last_name | gender | hire_date  |
+--------+------------+------------+-----------+--------+------------+
| 499999 | 1958-05-01 | Sachin     | Tsukuda   | M      | 1997-11-30 |
+--------+------------+------------+-----------+--------+------------+

INSERT INTO employees VALUES (500000,'1958-05-01','Test','Tsukuda','M','1997-11-30');
(1142, "INSERT command denied to user 'guest'@'localhost' for table 'employees'")
mycli -uroot -p123456

GRANT INSERT ON employees.* TO guest@localhost IDENTIFIED BY '123456';
mycli -uguest -p123456

USE employees;

INSERT INTO employees VALUES (500000,'1958-05-01','Test','Tsukuda','M','1997-11-30');

SELECT * FROM employees ORDER BY emp_no desc LIMIT 1;
+--------+------------+------------+-----------+--------+------------+
| emp_no | birth_date | first_name | last_name | gender | hire_date  |
+--------+------------+------------+-----------+--------+------------+
| 500000 | 1958-05-01 | Test       | Tsukuda   | M      | 1997-11-30 |
+--------+------------+------------+-----------+--------+------------+

REVOKE

mycli -uroot -p123456

REVOKE INSERT ON employees.* FROM guest@localhost;
mycli -uguest -p123456

USE employees;

INSERT INTO employees VALUES (500000,'1958-05-01','Test','Tsukuda','M','1997-11-30');
(1142, "INSERT command denied to user 'guest'@'localhost' for table 'employees'")

TCL

  • TCL(Transaction Control Language): it is used to manage transactions in the database

COMMIT

START TRANSACTION;

UPDATE employees SET last_name = 'Test' WHERE first_name = 'Test'

SELECT * FROM employees ORDER BY emp_no desc LIMIT 1;
+--------+------------+------------+-----------+--------+------------+
| emp_no | birth_date | first_name | last_name | gender | hire_date  |
+--------+------------+------------+-----------+--------+------------+
| 500000 | 1958-05-01 | Test       | Test      | M      | 1997-11-30 |
+--------+------------+------------+-----------+--------+------------+

UPDATE employees SET gender = 'F' WHERE first_name = 'Test'

SELECT * FROM employees ORDER BY emp_no desc LIMIT 1;
+--------+------------+------------+-----------+--------+------------+
| emp_no | birth_date | first_name | last_name | gender | hire_date  |
+--------+------------+------------+-----------+--------+------------+
| 500000 | 1958-05-01 | Test       | Test      | F      | 1997-11-30 |
+--------+------------+------------+-----------+--------+------------+

COMMIT

ROLLBACK

ROLLBACK

SELECT * FROM employees ORDER BY emp_no desc LIMIT 1;
+--------+------------+------------+-----------+--------+------------+
| emp_no | birth_date | first_name | last_name | gender | hire_date  |
+--------+------------+------------+-----------+--------+------------+
| 500000 | 1958-05-01 | Test       | Test      | F      | 1997-11-30 |
+--------+------------+------------+-----------+--------+------------+
START TRANSACTION;

UPDATE employees SET hire_date = '2000-01-01' WHERE first_name = 'Test';

SELECT * FROM employees ORDER BY emp_no desc LIMIT 1;
+--------+------------+------------+-----------+--------+------------+
| emp_no | birth_date | first_name | last_name | gender | hire_date  |
+--------+------------+------------+-----------+--------+------------+
| 500000 | 1958-05-01 | Test       | Test      | F      | 2000-01-01 |
+--------+------------+------------+-----------+--------+------------+

ROLLBACK

SELECT * FROM employees ORDER BY emp_no desc LIMIT 1;
+--------+------------+------------+-----------+--------+------------+
| emp_no | birth_date | first_name | last_name | gender | hire_date  |
+--------+------------+------------+-----------+--------+------------+
| 500000 | 1958-05-01 | Test       | Test      | F      | 1997-11-30 |
+--------+------------+------------+-----------+--------+------------+

参考

相关文章

网友评论

      本文标题:MySQL命令(一)

      本文链接:https://www.haomeiwen.com/subject/ovgfwftx.html