本篇文章来回顾一下MySQL的基本操作之DDL,DML,DQL,DCL,每种操作都有各自不同的语法,常用的操作汇总如下。

一、DDL-数据定义语言

作用:数据定义语言主要用来定义数据库中的各类对象,包括用户、库、表、视图、索引、触发器、事件、存储过程和函数等。

常见的DDL操作的基本用法如下:

CREATE USER           #创建用户CREATE DATABASE       #创建数据库CREATE TABLE          #创建表CREATE VIEW           #创建视图CREATE INDEX          #创建索引CREATE TRIGGER        #创建触发器CREATE EVENT          #创建事件CREATE PROCEDURE      #创建存储过程CREATE FUNCTION       #创建自定义函数...其他不常用的DDL(如:TABLESPACE)操作可自行查阅资料...

1、创建用户

用法:

'username'@

参数解释:

username:表示登陆MySQL实例的用户名[ip/domain/ip range]:表示数据库实例允许的登陆ip,域名或者ip段

示例:创建一个名称为bingwang,登陆ip为192.168.0.10的用户:

'bingwang'@

2、创建数据库

用法:

CREATE DATABASE db_name;

示例:创建一个名称为test_db,字符集为utf8的数据库

mysql> CREATE DATABASE test_db DEFAULT CHARSET UTF8;

3、创建表

用法:

CREATE TABLE table_name;

示例:创建一个名称为t_test,字符集为utf8,存储引擎为InnoDB,字符校验集为utf8_general_ci的表:

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;

4、创建视图

详细用法:

CREATE VIEW view_name as ;

参数解释:

:查询语句

示例:创建一个视图t_view,用来查询t_test中的ID为1或者2的数据:

FROM t_test WHERE id IN (1,2);

查看创建视图的过程:

mysql> SHOW CREATE VIEW test_view;

5、创建索引

有两种方法,CREATE和ALTER,下面先介绍一下CREATE的语法

用法:

INDEX index_name ON table_name(field[num]) ;

参数解释: 

UNIQUE:表示创建的索引类型为唯一索引,如果创建的为一般索引可以忽略该选项;table_name:表名称;field:表中的某个字段。num为可选参数,如果field为字符创类型,表示给该字段的前num个字符创建索引;OPTIONS:表示可选选项,可以指定索引使用的算法,比如:USING BTREE。不指定默认为BTREE;

示例:

(1)给t_test表中的name字段添加一个唯一索引,使用BTREE作为其索引算法:

CREATE UNIQUE INDEX name_ind ON t_test(name) USING BTREE;

(2)给t_test表中的name字段的前5个字符创建一般索引,使用BTREE作为其索引算法:

CREATE INDEX name_index ON t_test(name(5));

关于索引的更多用法及优化在后面的文章中会详细讲解。

6、创建触发器

用法:

CREATE TRIGGER trigger_name trigger_time trigger_event FOR EACH ROW BEGIN   trigger_stmt END;

示例:创建触发器内容稍多,此处先稍微提一下,后面专门章节介绍;

7、创建存储过程

用法:

CREATE PROCEDURE procedure_name([proc_parameter[,...]])BEGIN  ...存储过程体END

示例:创建存储过程内容稍多,此处先稍微提一下,后面专门章节介绍;

8、创建自定义函数

CREATE FUNCTION function_name([func_parameter[,...]])RETURNS typeBEGIN...函数体END

示例:创建自定义函数内容稍多,此处先稍微提一下,后面专门章节介绍;

至此,简单的DDL操作介绍完成。

二、DML-数据操纵语言

作用:用来操作数据库中的表对象,主要包括的操作有:INSERT,UPDATE,DELETE

常见的DML的基本操作方法如下:

#给表中添加数据INSERT INTO ...

#修改表中的数据UPDATE table_name SET ...

#删除表中的数据DELETE FROM table_name WHERE ;

注意:表示DML操作时的条件

1、向表中插入数据

用法:

INSERT INTO table_name(field1,field2,[,...]) values(value1,value2),(value3,value4),...;

示例:向学生表中插入一条数据,name:'xiaohong', age:24, gender:'M' ,如下:

(1)创建表:

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)插入数据:

INSERT INTO student(name,age,gender) VALUES('xiaohong',24,'M');

注意:主键如果自动递增,插入时可不用指定;

2、修改表中的数据

用法:

UPDATE table_name SET field1 = value1, field2 = value2, ... , WHERE ;

示例:将student表中id为1的记录中的name值修改为:"xiaohua",如下:

'xiaohua' WHERE id = 

注意:此处修改的时候,一定得注意加条件,否则整个表都会被改。讲个技巧:在MySQL的命令中执行操作的时候,可以在登录MySQL时添加-U选项,如果忘加条件,会被阻止执行sql语句。登录命令如下:

@WB-BLOG ~]# mysql -uroot -proot -U -h127.0.0.1 -P3306

可见:登录之后如果不加条件执行UPDATE语句,会被阻止;

3、删除表中的数据

详细用法:

mysql> DELETE FROM table_name WHERE ;

示例:删除student表中id为1的记录,如下:

1;

注意:

注意!注意!!再注意!!!,该操作非常危险,命令行中操作时,需要万分注意。可以使用登录时加-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操作介绍完毕。

三、DQL-数据查询语言

作用:主要用来查看表中的数据,也是平时使用最多的操作,主要命令为SELECT,基本用法如下:

mysql> SELECT fields FROM table_name WHERE ;

注意:

fields:表示要查询的字段列表,可以使用代替,但是在程序中最好别写,因为使用*一方面会降低SQL的查询效率,查询到一些用不到的字段;另一方面,使用一些ORM框架时,如果数据库中字段有变动,可能会立刻导致程序报错。

1、不加条件的单表查询

用法:

mysql> SELECT * FROM table;

示例略。

2、单表中的条件查询

常见的条件:

>,>=,,!=,IN,NOT IN,LIKE,NOT LIKE,REGEXP

示例:

23的记录

注意:

(1)当某个字段上有索引时,使用上述的反向查询或者前模糊查询,如:<>,!=,NOT LIKE,NOT IN,LIKE "%test",将会不走索引;

(2)查询中的潜在问题:如果某个字段在创建表结构的时候未设置非空,则使用WHERE name!="BING"的时候,将不会包含name为NULL的记录;

示例:查询student表中年龄大于"xiaohong"年龄的记录的数量:

SELECT COUNT(*) FROM student WHERE age > (SELECT age FROM student WHERE name = 'xiaohong');

3、分页查询

用法:

mysql> SELECT * FROM table_name LIMIT start,num;

参数解释:

start:开始位置,默认从0开始;

num:偏移量,即:从开始位置向后查询的数据条数;

示例:查询test表中,第二页的数据,每页显示10条,如下:

1,

4、使用ORDER BY对查询结果进行排序

基本用法:

SELECT * FROM table_name  ORDER BY  ASC/DESC;

示例:从student表中查询出所有年龄大于20的学生记录,并且按照年龄age倒序排列,如下:

20 ORDER BY age DESC;

注意:如果在排序时ORDER BY 之后没有添加DESC和ASC关键字,默认按照ASC升序排列;

5、使用GROUP BY对查询结果集进行分组

用法:

mysql> SELECT res FROM table_name  GROUP BY ;

示例:查询student表中男生和女生的数量:

mysql> SELECT gender,COUNT(*) FROM student GROUP BY gender;

6、使用GROUP BY之后,在使用HAVING完成分组之后的条件查询

用法:

SELECT res FROM table_name  GROUP BY  ;

示例:查询student_course表中有3门成绩大于等于80的学生学号

(1)创建测试表结构:

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);

(3)查询:

80 THEN 

四、DCL-数据控制语言

作用:用来授予或回收访问数据库的某种特权,并控制数据库操纵事务发生的时间及效果。

1、GRANT授予用户权限

基本用法:

mysql> GRANT priv_type ON  TO user ;

示例:给用户jerry授予对test_db数据库的增删改查权限,允许该用户从IP为'192.168.0.10'的网络登录(1)方法一:

'jerry'@

(2)方法二:

'jerry'@

2、REVOKE收回用户权限用法:

mysql> REVOKE priv_type ON  FROM 'jerry'@'192.168.0.10';

示例:收回用户对test_db库的删除权限:

'jerry'@

3、查看给某个用户所授予的权限

用法:

mysql> SHOW GRANTS FOR user;

示例:查询给'jerry'@'192.168.0.10'所授予的所有权限:

'jerry'@

4、查询可授予的所有权限,使用技巧

(1)授予所有权限

首先将某个库(如:test_db)的所有权限授予给用户'jerry'@'localhost'

'jerry'@

(2)收回某个权限

如:查询权限

'jerry'@

(3)查看剩余权限

这样就可以查到除了查询权限之外的权限,再加上查询权限即可授予的所有权限,如下:

'jerry'@

至此,MySQL的基本操作DDL,DML,DQL,DCL介绍完毕。

关注菜鸟封神记,定期分享技术干货!

点赞和在看是最大的支持,感谢↓↓↓

dml语句包括哪些_聊聊MySQL基本操作DDL,DML,DQL,DCL相关推荐

  1. mysql数据库DDL,DML,DCL操作

    mysql数据库操作 文章目录 mysql数据库操作 1:mysql工具使用 2:服务器监听的两种socket地址 3:mysql数据库数值类型 4:DDL操作 4.1 数据库操作 4.2:表操作 4 ...

  2. 【数据库1】mysql,DDL/DML,DQL,外键约束,多表/子查询,事务,登陆,连接池,jdbc,redis,crontab,ftp,oracle,数据交换/存储/收集

    文章目录 1.mysql安装:存储:集合(内存:临时),IO流(硬盘:持久化) 1.1 服务端:双击mysql-installer-community-5.6.22.0.msi 1.2 客户端:命令行 ...

  3. Mysql的DDL DML DQL DCL

    m代表长度(1-65) d代表保留少数位(0-30) 整数型 tinyint(m)1字节 取值范围(-128-+127) int(m)4字节 取值范围(大概20几亿) 浮点型 double(m,d)8 ...

  4. MySQL 的DDL DML DQL DCL细节解析 知道这些就够了

    SQL语言一共分为4大类:数据定义语言DDL,数据操纵语言DML,数据查询语言DQL,数据控制语言DCL 1.数据定义语言DDL(Data Definition Language) 对象: 数据库和表 ...

  5. 在mysql中更新数据sql语句怎么写_在MySQL中,更新数据库表记录的SQL语句,包括______语句...

    在MySQL中,更新数据库表记录的SQL语句,包括______语句 答:insert replace update delete 在域F中,设其特征为2,对于任意a,b∈F,则(a+b)2 等于多少 ...

  6. dml语句包括哪些_MySQL数据操作(DML)语句,入门掌握这些足够了

    DML是(Data Manipulation Languages)数据定义语言的缩写 主要包括表记录的插入insert.更新update.删除select 插入记录 insert into table ...

  7. mysql使用什么语句为指定_在MySQL中,可以使用_____语句来为指定数据库添加用户。...

    [简答题]ZX14-04-22电子被限制在一维相距 的两个不可穿透壁之间, ,试求 (1)电子最低能态的能量是多少? (2)如果E 1 是电子最低能态的能量,则电子较高一级能态的能量是多少? (3)如 ...

  8. mysql5.6 函数索引_聊聊MySQL中的索引

    关于MySQL中的索引使用 索引是数据库优化中最常用也是最重要的手段之一,通过索引通常可以帮助用户解决大多数的SQL性能问题. 索引的存储分类: 1.B-Tree索引:最常见的索引类型,大部分引擎都支 ...

  9. mysql 子查询概念_聊聊MySQL的子查询

    1. 背景 在之前介绍MySQL执行计划的博文中已经谈及了一些关于子查询相关的执行计划与优化.本文将重点介绍MySQL中与子查询相关的内容,设计子查询优化策略,包含半连接子查询的优化与非半连接子查询的 ...

最新文章

  1. 第一个以自己语言描述GBDT算法
  2. im即时通讯源码_IM消息ID技术专题(六):深度解密滴滴的高性能ID生成器(Tinyid)
  3. r graphics installing package
  4. uedit富文本编辑器
  5. time-formater 时间格式化插件
  6. 如何使用Chrome command API查找SAP Spartacus的router-outlet
  7. @valid 校验_SpringBoot数据校验与优雅处理详解
  8. oracle sql练习_使用Scrapy爬虫,并将数据存储到oracle
  9. linux top功能,[每日一题]说说Linux top命令的功能和用法
  10. java连接mysql数据库 R_Java连接Mysql数据库详细代码实例
  11. 鸟哥的Linux私房菜-基础篇(第九章)
  12. micro usb接口定义图
  13. Javaweb(html+css+javascript)
  14. NVIDIA GPU显卡介绍
  15. 阿里总参谋长曾鸣:区块链中没有绝对的“去中心化”
  16. 《卧底经济学》书中精髓:我们如何正确理解“稀缺”这件事儿?
  17. 什么是AJAX四步?分别是?(AJAX的使用)
  18. 【HDL系列】乘法器(5)——Radix-2 Booth乘法器
  19. 指针笔试题详细介绍,让你不再惧怕指针【c语言】
  20. 将串口接收的数据绘制成波形图(使用matlab或Visual Scope)

热门文章

  1. @namedqueries_在@NamedQueries中枚举@NamedQuery
  2. spring bean依赖_Spring @Configuration并将bean依赖项作为方法参数注入
  3. Spring Boot中的高级配置文件管理
  4. Java中的PriorityBlockingQueue
  5. 通过JavaFX标注制作动画效果
  6. 使用UAA OAuth2授权服务器–客户端和资源
  7. perl大骆驼和小骆驼_你好骆驼:自动文件传输
  8. ANTLR和Jetbrains MPS:解析文件并以树符号显示AST
  9. guice spring_Spring vs Guice:重要的一个关键区别
  10. 发现大量Java原语集合处理