MySQL基本操做之DDL(数据定义语言),DML(数据操纵语言),DQL(数据查询语言),DCL(数据控制语言)
1、DDL--数据定义语言
做用:数据定义语言主要用来定义数据库中的各种对象,包括用户、库、表、视图、索引、触发器、事件、存储过程和函数等。
常见的DDL操做的基本用法以下:html
CREATE USER #建立用户 CREATE DATABASE #建立数据库 CREATE TABLE #建立表 CREATE VIEW #建立视图 CREATE INDEX #建立索引 CREATE TRIGGER #建立触发器 CREATE EVENT #建立事件 CREATE PROCEDURE #建立存储过程 CREATE FUNCTION #建立自定义函数 ...其余不经常使用的DDL(如:TABLESPACE)操做可自行查阅资料...
一、建立用户:
详细用法:CREATE USER 'username'@'[ip/domain/netmask]'mysql
参数解释: username:表示登录MySQL实例的用户名 [ip/domain/ip range]:表示数据库实例容许的登录ip,域名或者ip段
示例:建立一个名称为bingwang,登录ip为192.168.0.10的用户:正则表达式
mysql> CREATE USER 'bingwang'@'192.168.0.10';
二、建立数据库,示例以下:算法
详细用法:sql
CREATE DATABASE db_name;
示例以下:数据库
#建立一个名称为test_db,字符集为utf8的数据库 mysql> CREATE DATABASE test_db DEFAULT CHARSET UTF8;
三、建立表:网络
详细用法:CREATE TABLE table_name;
示例以下:框架
#建立一个名称为t_test,字符集为utf8,存储引擎为InnoDB,字符校验集为utf8_general_ci的表: mysql> CREATE TABLE t_test ( id INT NOT NULL AUTO_INCREMENT, name VARCHAR(50), PRIMARY KEY(id) ) ENGINE = InnoDB DEFAUL CHARSET = UTF8 COLLATE = utf8_general_ci;
四、建立视图:dom
详细用法:函数
CREATE VIEW view_name as <SELECT phrase>; 参数解释: <SELECT phrase>:查询语句
示例以下:
#建立一个视图t_view,用来查询t_test中的ID为1或者2的数据: mysql> CREATE VIEW test_view AS SELECT * FROM t_test WHERE id IN (1,2); #查看建立视图的过程: mysql> SHOW CREATE VIEW test_view;
五、建立索引,有两种方法,CREATE和ALTER,下面先介绍一下CREATE:
详细用法:
CREATE [UNIQUE] INDEX index_name ON table_name(field[num]) <OPTIONS>; 参数解释: UNIQUE:表示建立的索引类型为惟一索引,若是建立的为通常索引能够忽略该选项 table_name:表名称 field:表中的某个字段。num为可选参数,若是field为字符创类型,表示给该字段的前num个字符建立索引 OPTIONS:表示可选选项,能够指定索引使用的算法,好比:USING BTREE。不指定默认为BTREE;
示例以下:
(1)给t_test表中的name字段添加一个惟一索引,使用BTREE做为其索引算法:
mysql> CREATE UNIQUE INDEX name_ind ON t_test(name) USING BTREE; mysql> SHOW [INDEX/INDEXES] FROM t_test; #查看t_test表中的索引,[INDEX/INDEXES]两个关键字均可以
(2)给t_test表中的name字段的前5个字符建立通常索引,使用BTREE做为其索引算法:
mysql> CREATE INDEX name_index ON t_test(name(5));
关于索引的更多用法及优化在后面的文章中会详细讲解。
六、建立触发器:
详细用法:
CREATE TRIGGER trigger_name trigger_time trigger_event FOR EACH ROW BEGIN trigger_stmt END;
示例:建立触发器内容稍多,此处先稍微提一下,后面专门章节介绍;
七、建立存储过程:
详细用法:
CREATE PROCEDURE procedure_name([proc_parameter[,...]]) BEGIN ...存储过程体 END
示例:建立存储过程内容稍多,此处先稍微提一下,后面专门章节介绍;
八、建立自定义函数:
详细用法:
CREATE FUNCTION function_name([func_parameter[,...]]) RETURNS type BEGIN ...函数体 END
示例:建立自定义函数内容稍多,此处先稍微提一下,后面专门章节介绍;
至此,简单的DDL操做介绍完成。
2、DML--数据操纵语言:
做用:用来操做数据库中的表对象,主要包括的操做有:INSERT,UPDATE,DELETE
常见的DML的基本操做方法以下:
#给表中添加数据 INSERT INTO ... #修改表中的数据 UPDATE table_name SET ... #删除表中的数据 DELETE FROM table_name WHERE <condition>; 注:<condition>:表示DML操做时的条件
一、向表中插入数据:
详细用法:
mysql> INSERT INTO table_name(field1,field2,[,...]) values(value1,value2),(value3,value4),...;
示例:向学生表中插入一条数据,name:'xiaohong', age:24, gender:'M' ,以下:
(1)建立表:
mysql> CREATE TABLE student( id INT PRIMARY KEY AUTO_INCREMENT, name VARCHAR(50) NOT NULL DEFAULT '', age TINYINT, gender ENUM('F','M') ) ENGINE = InnoDB DEFAULT CHARSET = UTF8;
(2)插入数据:
mysql> INSERT INTO student(name,age,gender) VALUES('xiaohong',24,'M'); Query OK, 1 row affected (0.09 sec) mysql> SELECT * FROM student; +----+----------+------+--------+ | id | name | age | gender | +----+----------+------+--------+ | 1 | xiaohong | 24 | M | +----+----------+------+--------+ 1 row in set (0.37 sec) 注:主键若是自动递增,插入时可不用指定;
二、修改表中的数据:
详细用法:
UPDATE table_name SET field1 = value1, field2 = value2, ... , WHERE <condition>;
示例:将student表中id为1的记录中的name值修改成:"xiaohua",以下:
mysql> UPDATE STUDENT SET name = 'xiaohua' WHERE id = 1; Query OK, 1 row affected (0.67 sec) Rows matched: 1 Changed: 1 Warnings: 0 mysql> SELECT * FROM student; +----+---------+------+--------+ | id | name | age | gender | +----+---------+------+--------+ | 1 | xiaohua | 24 | M | +----+---------+------+--------+ 1 row in set (0.00 sec)
注意:此处修改的时候,必定得注意加条件,不然整个表都会被改。讲个技巧:在MySQL的命令中执行操做的时候,能够在登陆MySQL时添加-U选项,若是忘加条件,会被阻止执行sql语句。登陆命令以下:
[root@WB-BLOG ~]# mysql -uroot -proot -U -h127.0.0.1 -P3306 mysql> UPDATE STUDENT SET name = 'hong'; ERROR 1175 (HY000): You are using safe update mode and you tried to update a table without a WHERE that uses a KEY column
可见:登陆以后若是不加条件执行UPDATE语句,会被阻止;
三、删除表中的数据:
详细用法:
mysql> DELETE FROM table_name WHERE <condition>;
示例:删除student表中id为1的记录,以下:
mysql> DELETE FROM student WHERE id = 1; Query OK, 1 row affected (0.37 sec) mysql> SELECT * FROM student; Empty set (0.00 sec)
注意:注意!注意!!再注意!!!,该操做很是危险,命令行中操做时,须要万分注意。可使用登陆时加-U参数的方式,防止忘加条件而删除全部数据,加了-U参数以后,若是不加条件,会被阻止,执行结果以下:
mysql> DELETE FROM student; ERROR 1175 (HY000): You are using safe update mode and you tried to update a table without a WHERE that uses a KEY column
至此,DML操做介绍完毕。
3、DQL--数据查询语言
做用:主要用来查看表中的数据,也是平时使用最多的操做,主要命令为:SELECT
基本用法以下:
mysql> SELECT fields FROM table_name WHERE <condition>;
注意事项:
fields:表示要查询的字段列表,可使用代替,可是在程序中最好别写,由于使用*一方面会下降SQL的查询效率,查询到一些用不到的字段;另外一方面,使用一些ORM框架时,若是数据库中字段有变更,可能会马上致使程序报错。
一、简单不加条件的单表查询:
用法:
mysql> SELECT * FROM table;
示例略。
二、单表中的条件查询:
常见的条件:>,>=,<,<= ,=,<>,!=,IN,NOT IN,LIKE,NOT LIKE,REGEXP
示例:
#查询年龄大于23的记录 mysql> SELECT * FROM student WHERE age > 23; #查询年龄大于等于24的记录,和上面age>23结果相同 mysql> SELECT * FROM student WHERE age >= 24; #查询年龄小于24的记录 mysql> SELECT * FROM student WHERE age < 24; #查询年龄小于等于24的记录 mysql> SELECT * FROM student WHERE age <= 24; #查询姓名等于xiaohong的记录 mysql> SELECT * FROM student WHERE name = 'xiaohong'; #查询姓名不等于xiaohong的记录 mysql> SELECT * FROM student WHERE name <> 'xiaohong'; #查询姓名不等于xiaohong的记录 mysql> SELECT * FROM student WHERE name != 'xiaohong'; #查询姓名为xiaohong或者xiaohui的记录 mysql> SELECT * FROM student WHERE name in ('xiaohong','xiaohui'); #查询姓名不是xiaohong和xiaohui的记录等价于:where name != xiaohong and name != xiaohui mysql> SELECT * FROM student WHERE name not in ('xiaohong','xiaohui'); #查询姓名以xiao开头的记录 mysql> SELECT * FROM student WHERE name like 'xiao%'; #查询姓名以xiaohon开头的记录,后面模糊匹配一位,如:xiaohong,xiaohoni mysql> SELECT * FROM student WHERE name like 'xiaohon_'; #查询姓名中包含ao字符创的记录 mysql> SELECT * FROM student WHERE name like '%ao%'; #查询以hong结尾的记录 mysql> SELECT * FROM student WHERE name not like '%hong'; #使用正则表达式查询姓名以xiao开头的记录 mysql> SELECT * FROM student WHERE name REGEXP('^xiao'); #使用正则表达式查询姓名以hong结尾的记录 mysql> SELECT * FROM student WHERE name REGEXP('hong$'); #支持的其余复杂的正则表达式,请参阅资料:
正则表达式教程:http://www.runoob.com/regexp/...
注意:
(1)当某个字段上有索引时,使用上述的反向查询或者前模糊查询,如:<>,!=,NOT LIKE,NOT IN,LIKE "%test",将会不走索引;
(2)查询中的潜在问题:若是某个字段在建立表结构的时候未设置非空,则使用WHERE name!="BING"的时候,将不会包含name为NULL的记录;
示例:查询student表中年龄大于"xiaohong"年龄的记录的数量:
mysql> SELECT COUNT(*) FROM student WHERE age > (SELECT age FROM student WHERE name = 'xiaohong'); +----------+ | COUNT(*) | +----------+ | 2 | +----------+ 1 row in set (0.46 sec)
三、分页查询:
用法:
mysql> SELECT * FROM table_name LIMIT start,num;
参数解释:
start:开始位置,默认从0开始;
num:偏移量,即:从开始位置向后查询的数据条数;
示例:查询test表中,第二页的数据,每页显示10条,以下:
mysql> SELECT * FROM student LIMIT 1,10;
四、使用ORDER BY对查询结果进行排序:
用法:
SELECT * FROM table_name <where condition> ORDER BY <field> ASC/DESC;
示例:从student表中查询出全部年龄大于20的学生记录,而且按照年龄age倒序排列,以下:
SELECT * FROM student WHERE age > 20 ORDER BY age DESC;
注意:若是在排序时ORDER BY <field>以后没有添加DESC和ASC关键字,默认按照ASC升序排列;
五、使用GROUP BY对查询结果集进行分组
基本用法:
mysql> SELECT res FROM table_name <where condition> GROUP BY <field>;
示例:查询student表中男生和女生的数量:
mysql> SELECT gender,COUNT(*) FROM student GROUP BY gender;
六、使用GROUP BY以后,在使用HAVING完成分组以后的条件查询
基本用法:
SELECT res FROM table_name <where condition> GROUP BY <field> <having condition>;
示例:查询student_course表中有3门成绩大于等于80的学生学号
(1)建立测试表结构:
mysql> CREATE TABLE student_course( sno INT(11) NOT NULL, cno INT(11) NOT NULL, grade SMALLINT NOT NULL DEFAULT 0 )ENGINE = InnoDB DEFAULT CHARSET = UTF8;
(2)插入测试数据:
INSERT INTO student_course(sno,cno,grade) VALUES(1,100,79); INSERT INTO student_course(sno,cno,grade) VALUES(1,101,89); INSERT INTO student_course(sno,cno,grade) VALUES(1,102,87); INSERT INTO student_course(sno,cno,grade) VALUES(1,103,99); INSERT INTO student_course(sno,cno,grade) VALUES(2,100,90); INSERT INTO student_course(sno,cno,grade) VALUES(2,101,80); INSERT INTO student_course(sno,cno,grade) VALUES(2,102,77); INSERT INTO student_course(sno,cno,grade) VALUES(2,103,79); INSERT INTO student_course(sno,cno,grade) VALUES(3,100,89); INSERT INTO student_course(sno,cno,grade) VALUES(3,101,90); INSERT INTO student_course(sno,cno,grade) VALUES(3,102,83); INSERT INTO student_course(sno,cno,grade) VALUES(3,103,91);
(3)查询:
mysql> SELECT sno,SUM(CASE WHEN grade > 80 THEN 1 ELSE 0 END) num FROM student_course GROUP BY sno HAVING num >= 3; +-----+------+ | sno | num | +-----+------+ | 1 | 3 | | 3 | 4 | +-----+------+ 2 rows in set (0.45 sec)
4、DCL--数据控制语言
做用:用来授予或回收访问数据库的某种特权,并控制数据库操纵事务发生的时间及效果。
一、GRANT授予用户权限:
基本用法:
mysql> GRANT priv_type ON <object_type> TO user <WITH {GRANT OPTION | resource_option} ...>;
示例:给用户jerry授予对test_db数据库的增删改查权限,容许该用户从IP为'192.168.0.10'的网络登陆
(1)方法一:
mysql> GRANT INSERT,SELECT,UPDATE,DELETE ON test_db.* TO 'jerry'@'192.168.0.10' IDENTIFIED BY 'password' WITH GRANT OPTION;
(2)方法二:
mysql> CREATE USER 'jerry'@'192.168.0.10' IDENTIFIED BY 'password'; mysql> GRANT INSERT,SELECT,UPDATE,DELETE ON test_db.* TO 'jerry'@'192.168.0.10';
二、REVOKE收回用户权限:
基本用法:
mysql> REVOKE priv_type ON <object_type> FROM 'jerry'@'192.168.0.10';
示例:收回用户对test_db库的删除权限:
mysql> REVOKE DELETE ON test_db.* FROM 'jerry'@'192.168.0.10';
三、查看给某个用户所授予的权限:
基本用法:
mysql> SHOW GRANTS FOR user;
示例:查询给'jerry'@'192.168.0.10'所授予的全部权限:
mysql> SHOW GRANTS FOR 'jerry'@'192.168.0.10';
四、查询可授予的全部权限,使用技巧:
(1)首先将某个库(如:test_db)的全部权限授予给用户'jerry'@'localhost'
mysql> GRANT ALL ON test_db.* TO 'jerry'@'localhost' IDENTIFIED BY 'jerry';
(2)收回某个权限,如:查询权限
mysql> REVOKE SELECT ON test_db.* FROM 'jerry'@'localhost';
(3)查看剩余权限,就能够查到除了查询权限以外的权限,再加上查询权限便可授予的全部权限
mysql> SHOW GRANTS FOR 'jerry'@'localhost';
至此,MySQL的基本操做DDL,DML,DQL,DCL介绍完毕。
下面几回次章节专门介绍触发器、存储过程和函数,你们有什么想法或者但愿重点介绍MySQL的哪一个模块能够在下方留言,一块学习数据库,欢迎转发~
后续文章将更新在我的小站上,欢迎查看。