本篇文章来回顾一下MySQL的基本操作之DDL,DML,DQL,DCL,每种操作都有各自不同的语法,常用的操作汇总如下。
一、DDL-数据定义语言
作用:数据定义语言主要用来定义数据库中的各类对象,包括用户、库、表、视图、索引、触发器、事件、存储过程和函数等。
常见的DDL操作的基本用法如下:
CREATEDATABASE#创建数据库 CREATETABLE#创建表 CREATEVIEW#创建视图 CREATEINDEX#创建索引 CREATETRIGGER#创建触发器 CREATEEVENT#创建事件 CREATEPROCEDURE#创建存储过程 CREATEFUNCTION#创建自定义函数 ...其他不常用的DDL(如:TABLESPACE)操作可自行查阅资料...CREATEUSER#创建用户
1、创建用户
用法:
'username'@
参数解释:
username:表示登陆MySQL实例的用户名[ip/domain/ip range]:表示数据库实例允许的登陆ip,域名或者ip段
示例:创建一个名称为bingwang,登陆ip为192.168.0.10的用户:
'bingwang'@
2、创建数据库
用法:
CREATEDATABASEdb_name;
示例:创建一个名称为test_db,字符集为utf8的数据库
mysql>CREATEDATABASEtest_dbDEFAULTCHARSETUTF8;
3、创建表
用法:
CREATETABLEtable_name;
示例:创建一个名称为t_test,字符集为utf8,存储引擎为InnoDB,字符校验集为utf8_general_ci的表:
idINTNOTNULLAUTO_INCREMENT, nameVARCHAR(50), PRIMARYKEY(id) )ENGINE=InnoDBDEFAULCHARSET=UTF8COLLATE=utf8_general_ci;CREATETABLEt_test(
4、创建视图
详细用法:
CREATEVIEWview_nameas;
参数解释:
:查询语句
示例:创建一个视图t_view,用来查询t_test中的ID为1或者2的数据:
FROMt_testWHEREidIN(1,2);
查看创建视图的过程:
mysql>SHOWCREATEVIEWtest_view;
5、创建索引
有两种方法,CREATE和ALTER,下面先介绍一下CREATE的语法
用法:
INDEXindex_nameONtable_name(field[num]);
参数解释:
UNIQUE:表示创建的索引类型为唯一索引,如果创建的为一般索引可以忽略该选项;table_name:表名称;field:表中的某个字段。num为可选参数,如果field为字符创类型,表示给该字段的前num个字符创建索引;OPTIONS:表示可选选项,可以指定索引使用的算法,比如:USING BTREE。不指定默认为BTREE;
示例:
(1)给t_test表中的name字段添加一个唯一索引,使用BTREE作为其索引算法:
CREATEUNIQUEINDEXname_indONt_test(name)USINGBTREE;
(2)给t_test表中的name字段的前5个字符创建一般索引,使用BTREE作为其索引算法:
CREATEINDEXname_indexONt_test(name(5));
关于索引的更多用法及优化在后面的文章中会详细讲解。
6、创建触发器
用法:
BEGIN trigger_stmt END;CREATETRIGGERtrigger_nametrigger_timetrigger_eventFOREACHROW
示例:创建触发器内容稍多,此处先稍微提一下,后面专门章节介绍;
7、创建存储过程
用法:
BEGIN ...存储过程体 ENDCREATEPROCEDUREprocedure_name([proc_parameter[,...]])
示例:创建存储过程内容稍多,此处先稍微提一下,后面专门章节介绍;
8、创建自定义函数
RETURNStype BEGIN ...函数体 ENDCREATEFUNCTIONfunction_name([func_parameter[,...]])
示例:创建自定义函数内容稍多,此处先稍微提一下,后面专门章节介绍;
至此,简单的DDL操作介绍完成。
二、DML-数据操纵语言
作用:用来操作数据库中的表对象,主要包括的操作有:INSERT,UPDATE,DELETE
常见的DML的基本操作方法如下:
INSERTINTO... #修改表中的数据 UPDATEtable_nameSET... #删除表中的数据 DELETEFROMtable_nameWHERE;#给表中添加数据
注意:表示DML操作时的条件
1、向表中插入数据
用法:
INSERTINTOtable_name(field1,field2,[,...])values(value1,value2),(value3,value4),...;
示例:向学生表中插入一条数据,name:'xiaohong', age:24, gender:'M' ,如下:
(1)创建表:
idINTPRIMARYKEYAUTO_INCREMENT, nameVARCHAR(50)NOTNULLDEFAULT'', ageTINYINT, genderENUM('F','M') )ENGINE=InnoDBDEFAULTCHARSET=UTF8;CREATETABLEstudent(
(2)插入数据:
INSERTINTOstudent(name,age,gender)VALUES('xiaohong',24,'M');
注意:主键如果自动递增,插入时可不用指定;
2、修改表中的数据
用法:
UPDATEtable_nameSETfield1=value1,field2=value2,...,WHERE;
示例:将student表中id为1的记录中的name值修改为:"xiaohua",如下:
'xiaohua'WHEREid=
注意:此处修改的时候,一定得注意加条件,否则整个表都会被改。讲个技巧:在MySQL的命令中执行操作的时候,可以在登录MySQL时添加-U选项,如果忘加条件,会被阻止执行sql语句。登录命令如下:
@WB-BLOG~]#mysql-uroot-proot-U-h127.0.0.1-P3306
可见:登录之后如果不加条件执行UPDATE语句,会被阻止;
3、删除表中的数据
详细用法:
mysql>DELETEFROMtable_nameWHERE;
示例:删除student表中id为1的记录,如下:
1;
注意:
注意!注意!!再注意!!!,该操作非常危险,命令行中操作时,需要万分注意。可以使用登录时加-U参数的方式,防止忘加条件而删除所有数据,加了-U参数之后,如果不加条件,会被阻止,执行结果如下:
ERROR1175(HY000):YouareusingsafeupdatemodeandyoutriedtoupdateatablewithoutaWHEREthatusesaKEYcolumnmysql>DELETEFROMstudent;
至此,DML操作介绍完毕。
三、DQL-数据查询语言
作用:主要用来查看表中的数据,也是平时使用最多的操作,主要命令为SELECT,基本用法如下:
mysql>SELECTfieldsFROMtable_nameWHERE;
注意:
fields:表示要查询的字段列表,可以使用代替,但是在程序中最好别写,因为使用*一方面会降低SQL的查询效率,查询到一些用不到的字段;另一方面,使用一些ORM框架时,如果数据库中字段有变动,可能会立刻导致程序报错。
1、不加条件的单表查询
用法:
mysql>SELECT*FROMtable;
示例略。
2、单表中的条件查询
常见的条件:
>,>=,,!=,IN,NOT IN,LIKE,NOT LIKE,REGEXP
示例:
23的记录
注意:
(1)当某个字段上有索引时,使用上述的反向查询或者前模糊查询,如:<>,!=,NOT LIKE,NOT IN,LIKE "%test",将会不走索引;
(2)查询中的潜在问题:如果某个字段在创建表结构的时候未设置非空,则使用WHERE name!="BING"的时候,将不会包含name为NULL的记录;
示例:查询student表中年龄大于"xiaohong"年龄的记录的数量:
SELECTCOUNT(*)FROMstudentWHEREage>(SELECTageFROMstudentWHEREname='xiaohong');
3、分页查询
用法:
mysql>SELECT*FROMtable_nameLIMITstart,num;
参数解释:
start:开始位置,默认从0开始;
num:偏移量,即:从开始位置向后查询的数据条数;
示例:查询test表中,第二页的数据,每页显示10条,如下:
1,
4、使用ORDER BY对查询结果进行排序
基本用法:
SELECT*FROMtable_nameORDERBYASC/DESC;
示例:从student表中查询出所有年龄大于20的学生记录,并且按照年龄age倒序排列,如下:
20ORDERBYageDESC;
注意:如果在排序时ORDER BY 之后没有添加DESC和ASC关键字,默认按照ASC升序排列;
5、使用GROUP BY对查询结果集进行分组
用法:
mysql>SELECTresFROMtable_nameGROUPBY;
示例:查询student表中男生和女生的数量:
mysql>SELECTgender,COUNT(*)FROMstudentGROUPBYgender;
6、使用GROUP BY之后,在使用HAVING完成分组之后的条件查询
用法:
SELECTresFROMtable_nameGROUPBY;
示例:查询student_course表中有3门成绩大于等于80的学生学号
(1)创建测试表结构:
snoINT(11)NOTNULL, cnoINT(11)NOTNULL, gradeSMALLINTNOTNULLDEFAULT0 )ENGINE=InnoDBDEFAULTCHARSET=UTF8;CREATETABLEstudent_course(
(2)插入测试数据:
INSERTINTOstudent_course(sno,cno,grade)VALUES(1,100,79);
(3)查询:
80THEN
四、DCL-数据控制语言
作用:用来授予或回收访问数据库的某种特权,并控制数据库操纵事务发生的时间及效果。
1、GRANT授予用户权限
基本用法:
mysql>GRANTpriv_typeONTOuser;
示例:给用户jerry授予对test_db数据库的增删改查权限,允许该用户从IP为'192.168.0.10'的网络登录(1)方法一:
'jerry'@
(2)方法二:
'jerry'@
2、REVOKE收回用户权限用法:
mysql>REVOKEpriv_typeONFROM'jerry'@'192.168.0.10';
示例:收回用户对test_db库的删除权限:
'jerry'@
3、查看给某个用户所授予的权限
用法:
mysql>SHOWGRANTSFORuser;
示例:查询给'jerry'@'192.168.0.10'所授予的所有权限:
'jerry'@
4、查询可授予的所有权限,使用技巧
(1)授予所有权限
首先将某个库(如:test_db)的所有权限授予给用户'jerry'@'localhost'
'jerry'@
(2)收回某个权限
如:查询权限
'jerry'@
(3)查看剩余权限
这样就可以查到除了查询权限之外的权限,再加上查询权限即可授予的所有权限,如下:
'jerry'@
至此,MySQL的基本操作DDL,DML,DQL,DCL介绍完毕。
关注菜鸟封神记,定期分享技术干货!
点赞和在看是最大的支持,感谢↓↓↓