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

fe4f8f33aebad5d1e295ce3681bcb97a.png

    本篇文章来回顾一下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 type
BEGIN
...函数体
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介绍完毕。

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

6eaf55d71628d5e9bc82a9b6351a3723.png

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/335450.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Windows 系统下使用 putty 客户端通过 SSH 远程连接 AWS 服务器

找到在购买亚马逊的AWS服务器时保存的密钥文件&#xff08;假设为abc.pem&#xff09;。 打开PuTTYgen&#xff0c;如下图&#xff0c;点击图中1处的“load”,找到abc.pem文件所在的位置&#xff0c;并选择abc.pem&#xff0c;确定&#xff1b; 然后&#xff0c;选择图中2处…

ip integrator_使用Oracle Data Integrator(和Kafka / MapR流)完善Lambda体系结构

ip integrator“ Lambda体系结构是一种数据处理体系结构&#xff0c;旨在通过利用批处理和流处理方法来处理大量数据。 这种体系结构方法尝试通过使用批处理提供批处理数据的全面而准确的视图&#xff0c;同时使用实时流处理提供在线数据的视图来平衡延迟 &#xff0c; 吞吐量和…

php 如何获取函数类型,PHP如何使用gettype()函数判断变量的类型?

gettype()函数是PHP中的一个内置函数&#xff0c;用于获取变量的类型&#xff1b;它可用于检查现有变量的类型。下面本篇文章就来给大家介绍一下gettype()函数&#xff0c;希望对大家有所帮助。【视频教程推荐&#xff1a;PHP教程】基本语法string gettype ( $var )参数&#x…

qfile 创建文件_Qt之二进制文件读写

点击上方“Qt学视觉”&#xff0c;选择“星标”公众号重磅干货&#xff0c;第一时间送达想要学习的同学们还请认真阅读每篇文章&#xff0c;相信你一定会有所收获除了文本文件之外&#xff0c;其他需要按照一定的格式定义读写的文件都称为二进制文件&#xff0c;每种格式的二进…

cloud foundry_实际的Reactor操作–检索Cloud Foundry应用程序的详细信息

cloud foundryCF-Java-Client是一个库&#xff0c;可通过程序访问Cloud Foundry Cloud Controller API 。 它建立在Project Reactor之上&#xff0c;它是Reactive Streams规范的实现&#xff0c;并且使用此库在Cloud Foundry环境中做一些实际的事情是一个有趣的练习。 考虑一个…

iis开启php验证码,php结合GD库实现中文验证码的简单方法

前言上一次写了一个常见的验证码&#xff0c;现在玩一下中文的验证码&#xff0c;顺便升级一下写的代码流程基本差不多先看GD库开启了没生成中文5位验证码开始画图画干扰素生成图形完事生成中文验证码//小小心机$hanzi "如果觉得写得还可以的话互相关注报团取暖交流经验来…

Linux 系统关于应该把程序安装在目录 /usr 还是目录 /usr/local 下的思考

对于一个以 LFS(Linux From Scratch 大意&#xff1a;自己做出来的 Linux) 为基础的系统来说&#xff0c;这是一个没有明确答案的问题。什么是 LFS&#xff1f; 在传统的 Unix 系统中&#xff0c;/usr 通常只包含系统发行时自带的程序&#xff0c;而 /usr/local 则是本地系统管…

数据结构设计_合并多种疾病,如何设计数据结构?

如果一个患者合并多种疾病或应用多种药物&#xff0c;如何设计数据结构&#xff1f;例如病史&#xff0c;建议设计成多选题。如果未患病&#xff0c;只需点一次“全无”&#xff0c;操作简单。如果选了全无&#xff0c;其他选框系统自动关闭&#xff0c;就不能再后面的选项了&a…

java ee的小程序_用微服务和容器替换旧版Java EE应用程序服务器

java ee的小程序Lightbend最近对2000多个JVM开发人员进行了一项调查&#xff0c;结果刚刚发布。 开展该调查的目的是发现&#xff1a;发展趋势与IT基础架构趋势之间的相关性&#xff0c;处于数字化转型前沿的组织如何使他们的应用程序现代化以及当今对新兴开发人员技术最为关注…

Linux系统下如何安装JDK?

一、首先下载linux版本jdk 点击进入jdk官网 根据自己的需求&#xff0c;下载不同版本的jdk 2.将下载好的jdk压缩包&#xff0c;通过ftp上传到linux系统的当前用户下&#xff0c;我当前登录的用户为root用户 3.将上传后的jdk&#xff0c;解压到/usr/local/目录下&#xff0c…

php网站模板怎么修改,网站后台模板修改

方法1、首先制作网站背景图片&#xff0c;这个建议找一些大尺寸的图片。(本图仅限测试使用)2、通过FTp工具链接到网站的空间&#xff0c;找到dedecms网站的模版文件templets。找到模版目录下的模版样式文件。如果使用的是默认模版&#xff0c;文件在templets/default/style/ded…

python练手经典100例微盘_Python练手项目实例汇总(附源码下载)

1 #_*_ coding:utf-8 _*_ 2 from tkinter import * 3 importrandom4 importtime5 importtkinter.messagebox6 7 8 #俄罗斯方块界面的高度 9 HEIGHT 20 10 11 #俄罗斯方块界面的宽度 12 WIDTH 10 13 14 ACTIVE 1 15 PASSIVE 016 TRUE 1 17 FALSE 018 19 style [20 [[(0,0),(…

Linux 环境变量设置及查看

文章目录一、设置变量的四种方法&#xff08;一&#xff09;在 /etc/profile 文件中添加变量&#xff08;二&#xff09;在用户目录下的 .bash_profile 文件中添加变量&#xff08;三&#xff09;使用命令 export 声明定义变量&#xff08;四&#xff09;使用命令 declare 声明…

docker 部署java_使用Docker堆栈部署的微服务-WildFly,Java EE和Couchbase

docker 部署java关于微服务的资料很多&#xff0c;只是用谷歌搜索就可以了 &#xff01; 几年前&#xff0c;我在比利时的Devoxx上发表了有关将单片重构为微服务的演讲&#xff0c;它获得了很好的评价&#xff1a; 该博客将展示Docker如何简化微服务的创建和关闭。 该博客中使…

django settings 定义的变量不存在_使用Django部署机器学习模型(1)

介绍机器学习(ML)应用的需求正在不断增长。许多资料显示了如何训练ML算法。然而&#xff0c;ML算法分为两个阶段:训练阶段——在这个阶段&#xff0c;基于历史数据训练ML算法&#xff0c;推理阶段——ML算法被用于计算对未知结果的新数据的预测。商业利益就处于推理阶段&#x…

php系统函数区分大小写,php函数名区分大小写吗?

PHP对大小写敏感问题的处理比较乱&#xff0c;写代码时可能偶尔出问题&#xff0c;所以下面本篇文章就来总结一下。有一定的参考价值&#xff0c;有需要的朋友可以参考一下&#xff0c;希望对你有所帮助。但我不是鼓励大家去用这些规则。推荐大家始终坚持“大小写敏感”&#x…

提取javadoc_使用JavaParser从源文件中提取JavaDoc文档

提取javadoc很多人正在使用JavaParser实现最不同的目标。 其中之一是提取文档。 在这篇简短的文章中&#xff0c;我们将看到如何打印与类或接口关联的所有JavaDoc注释。 可以在GitHub上找到代码&#xff1a; https : //github.com/ftomassetti/javadoc-extractor 获取类的所有…

python条形堆积图_python – 使用DataFrame.plot显示堆积条形图中...

您可以使用plt.text根据数据将信息放在位置. 但是,如果你有非常小的条形,可能需要一些调整才能看起来很完美. df_total df[Total Cost] df df.iloc[:, 0:4] df.plot(x Airport, kindbarh,stacked True, title Breakdown of Costs, mark_right True) df_rel df[df.column…

dmc matlab程序,matlab编的DMC程序.doc

matlab编的DMC程序clear all;% close all;%系统模型建立num[0.8];den[225 1];[a,b,c,d]tf2ss(num,den);% step(num,den);Ts30;lambda60;[ad,bd,cd,dd]c2dt(a,b,c,Ts,lambda);[numd,dend]ss2tf(ad,bd,cd,dd);[a,x]dstep(ad,bd,cd,dd);P10;M5;N50;%动态矩阵Afor i1:Pfor j1:Mif j…

mega2560单片机开发_[MEGA DEAL] Ultimate Java开发和认证指南(59%折扣)

mega2560单片机开发通过介绍世界上最受欢迎的编程语言之一掌握Java编程概念 嘿&#xff0c;怪胎&#xff0c; 本周&#xff0c;在我们的JCG Deals商店中 &#xff0c;我们提供了一个极端的报价 。 我们提供的《 Ultimate Java Development and Certification Guide 》 仅售2…