包括 SELECT, UPDATE, DELETE, INSERT


SELECT

从数据库表中获取数据

用法

SELECT name FROM students;
SELECT name,age FROM students;
SELECT * FROM students;

DISTINCT

使用 DISTINCT 可以对搜索结果进行去重

SELECT DISTINCT name FROM students;

ORDER BY

ORDER BY 根据指定的列对结果集进行排序

DESC 倒序、ASC 正序

SELECT * FROM students ORDER BY age DESC, name ASC;

LIMIT

LIMIT 用于规定要返回的记录的数目

SELECT * FROM students LIMIT 10;

UNION & UNION ALL

UNION 操作符用于合并两个或多个 SELECT 语句的结果集

UNION 自动去重,如果不希望去重可以使用 UNION

注意:UNION 内部的 SELECT 语句必须拥有相同数量的列,列也必须拥有相似的数据类型,并且每条 SELECT 语句中的列的顺序必须相同

SELECT * FROM students WHERE age < 18
UNION
SELECT * FROM students WHERE age > 100;
SELECT * FROM students WHERE age < 18
UNION ALL
SELECT * FROM students WHERE name LIKE 'A%';

WHERE

使用 WHERE 可以增加搜索条件

SELECT name FROM students WHERE age BETWEEN 0 AND 18;
SELECT name FROM students WHERE age < 18;

支持的操作符:><=<=>=<>(!=)、BETWEENLIKE

BETWEEN

BETWEEN ... AND 在 WHERE 子句中使用,作用是选取介于两个值之间的数据范围,可以是数值、文本或者日期

同时也可以通过 NOT 来选取这两个值之外的范围

注意: BETWEEN 的范围是同时包含左右两个值的

SELECT name FROM students WHERE age BETWEEN 0 AND 18;
SELECT name FROM students WHERE age NOT BETWEEN 0 AND 18;

IN

IN 操作符允许我们在 WHERE 子句中规定多个值

SELECT * FROM students WHERE name IN ('Tom', 'Jerry');

LIKE & RLIKE & REGEXP

LIKE

LIKE 操作符用于在 WHERE 子句中搜索列中的指定模式

LIKE 通常与 %_一起使用,如果不使用通配符 LIKE 就相当于 =

MySQL 中 LIKE 不支持 [charlist][^charlist] 通配符,需要使用正则进行匹配

SELECT * FROM students WHERE name LIKE 'A%';
SELECT * FROM students WHERE name NOT LIKE 'A%';
SELECT * FROM students WHERE name LIKE 'T_m';
RLIKE & REGEXP

MySQL中使用 RLIKE & REGEXP 操作符来进行正则表达式匹配,相比 LIKE 更加灵活

SELECT * FROM students WHERE name RLIKE '^[^a-c]';
SELECT * FROM students WHERE name REGEXP '^[^a-c].m';
^ 匹配字符串的开始
$ 匹配字符串的结束
. 匹配除了'\n'之外的任意单个字符
[charlist] 匹配列表所包含的任意一个字符
[^charlist] 匹配列表不包含的任意一个字符
| 匹配符号左边或右边的字符
* 匹配前面的表达式 0 次或多次,等价于{0,}
+ 匹配前面的表达式 1 次或多次,等价于{1,}
{n} 匹配前面的表达式至少 n 次
{n,m} 匹配前面的表达式至少 n 次,至多 m 次
通配符

% 替代一个或多个字符

_ 仅替代一个字符

[charlist] 字符列中的任何单一字符

[^charlist] 不在字符列中的任何单一字符

AND & OR

ANDOR 可在 WHERE 子语句中把两个或多个条件结合起来

AND 要求两个条件同时成立

OR 只用其中一条成立即可

ANDOR 形成复杂的表达式时,可以使用 () 将条件括起来

SELECT * FROM students WHERE (name LIKE 'A%' OR name LIKE 'B%') AND age>18;

UPDATE

更新数据库表中的数据

UPDATE students SET name = 'Jerry' WHERE name = 'Tom';
UPDATE students SET age = 18, gender = 'F' WHERE name = 'Alice';

DELETE

从数据库表中删除数据

DELETE FROM students WHERE name = 'Tom';

删除表中所有数据,但是表还保留

DELETE FROM students;

INSERT INTO

向数据库表中插入数据

INSERT INTO students VALUES ('Tom', 10, 'M'), ('Jerry', 9, 'M');
INSERT INTO students (name, gender) VALUES ('Tom', 'M');

MySQL SQL DML (数据操作语言)的更多相关文章

  1. 6.1课堂笔记—DML(数据操作语言),DQL查询语句

    一.DML(数据操作语言) InnoDB MyISAM 支持事务 不支持事务 不支持全文索引 支持全文索引 支持外键约束 不支持 命令查看默认存储引擎 show variables like '%st ...

  2. DML数据操作语言

    DML数据操作语言 用来对数据库中表的数据记录进行更新.(增删改) 插入insert -- insert into 表(列名1,列名2,列名3...) values (值1,值2,值3...):向表中 ...

  3. DML数据操作语言之增加,删除,更新

    1.数据的增加 数据的增加要用到insert语句  ,基本格式是: insert into <表名> (列名1,列名2,列名3,......) values (值1,值2,值3,..... ...

  4. ODPS SQL <for 数据操作语言DML>

    基本操作: 查询: SELECT [ALL | DISTINCT] select_expr, select_expr, ... FROM table_reference [WHERE where_co ...

  5. DML数据操作语言之谓词,case表达式

    谓词:就是返回值是真值的函数. 前面接触到的“>” “<” “=”等称为比较运算符,它们的正式名称就是比较谓词.因为它们比较之后返回的结果是真值. 由于谓词 返回的结果是一个真值 ,即tr ...

  6. DML数据操作语言之常用函数

    所谓函数,就是输入某一值,得到相应的输出结果的功能.相当于一个加工厂,给了原料,最终产出成品. 其中原料 就是参数(parameter). 产品 就是返回值. 函数大致可以分为以下五个种类: 算术函数 ...

  7. DML数据操作语言之复杂查询

    1.视图(View) 我们知道,在关系型数据库中,用来保存实际数据记录的是数据表.和表同等概念也是用来保存东西是:视图. 但是数据表是用来保存实际数据记录的,而视图是用来保存常用select语句的. ...

  8. DML数据操作语言之查询(二)

    当我们查询出了N条记录之后 ,我们知道一共是几条记录,或者这些记录某一字段(列值)的最大值,最小值,平均值等,就可以使用聚合函数. 1.聚合函数 聚合函数会将null 排除在外.但是count(*)例 ...

  9. DML数据操作语言之查询(一)

    1.select语句基础 基本语句格式:  select <列名>,.... from <表名>; select子句中列举出希望从表中查询出的列的名称,from子句则指定了选取 ...

随机推荐

  1. WinCC的画面使用技巧

    以下内容以VB脚本为主,仅在VB脚本无法实现的功能中使用C脚本. 画面导航 画面导航的作用是打开起始画面.前一张画面和后一张画面等,只能用C脚本实现. 打开起始画面:    OpenHomePictu ...

  2. new 关键字 和 newInstance() 方法的 区别

    区别1: new是一个关键字,可以说是一个指令: newInstance()是一个方法,Class对象的一个方法. 区别2: new主要作用是在内存中生成一个实例,而这个类可以没有提前加载到内从中: ...

  3. Java中Set与Set<?>到底区别在哪?

    您可能知道,无界通配符 Set<?> 可以容纳任何类型的元素,而原始类型Set也可以容纳任何类型的元素.那它们之间有什么区别呢? 1.关于Set<?>的两个事实 关于Set&l ...

  4. 《细说PHP》第四版 样章 第18章 数据库抽象层PDO 2

    18.2  PDO所支持的数据库 使用PHP可以处理各种数据库系统,包括MySQL.PostgreSQL.Oracle.MsSQL等.但访问不同的数据库系统时,其所使用的PHP扩展函数也是不同的.例如 ...

  5. 一文告诉你,Kafka在性能优化方面做了哪些举措!

    很多粉丝私信问我Kafka在性能优化方面做了哪些举措,对于相关问题的答案其实我早就写过了,就是没有系统的整理一篇,最近思考着花点时间来整理一下,下次再有粉丝问我相关的问题我就可以潇洒的甩个链接了.这个 ...

  6. Redis for OPS 04:主从复制

    写在前面的话 Redis 的主从其实和 MySQL 类似,更多的还是作为备份的功能存在,在复杂的 Rediis 集群架构中,主从也是不可或缺的. 主从复制 主从复制原理: 1. 从库通过命令连接到主库 ...

  7. 爬取bilibili首页菜单获取li内容

    代码: import requests from bs4 import BeautifulSoup def html_save(s): with open('哔哩哔哩.csv','a')as f: f ...

  8. Visual Studio 基础设置

    重置开发环境 菜单栏中选择“工具”/“导入和导出设置”/“重置所有设置” 设置行号 菜单栏中选择“工具”/“选项”/“文本编辑器”/“行号” 全屏显示 菜单栏中选择“视图”/“全屏显示” 为程序设置版 ...

  9. 【LeetCode】2. 两数相加

    题目 给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字.   如果,我们将这两个数相加起来,则会返回一个新的链表来表 ...

  10. 高效取余运算(n-1)&hash原理探讨

    Java的HashMap源码中用到的(n-1)&hash这样的运算,查找发现这是一种高效的求余数的办法,但其中的原理是什么呢为什么可以这么做呢? 先上结论:假设被除数是x,对于除数是2n的取余 ...