MySQL高级语句(一)
一、MySQL高级进阶SQL 语句
1、SELECT
2、DISTINCT
3、WHERE
5、IN
6、BETWEEN
7、通配符、LIKE
8、ORDER BY
9、| | 连接符
二、函数
1、数学函数
3、字符串函数
准备工作
1、安装MySQL数据库
2、实验准备,数据表配置
1 mysql -uroot -p
2 show databases;
3
4 create database train_ticket;
5 use train_ticket;
6 create table REGION(region varchar(10),site varchar(20));
7 create table FARE(site varchar(20),money int(10),date varchar(15));
8
9 desc REGION;
10 desc FARE;
11
12 insert into REGION values ('south','changsha');
13 insert into REGION values ('south','nanchang');
14 insert into REGION values ('north','beijing');
15 insert into REGION values ('north','tianjin');
16
17 insert into FARE values ('changsha',1000,'2021-01-30');
18 insert into FARE values ('nanchang',700,'2021-01-30');
19 insert into FARE values ('beijing',1500,'2021-01-30');
20 insert into FARE values ('tianjin',1200,'2021-01-30');
21 insert into FARE values ('beijing',2200,'2021-02-05');
22
23 select * from REGION;
24 select * from FARE;
一、MySQL高级进阶SQL 语句
1、SELECT
显示表格中一个或数个字段的所有资料
语法:SELECT 字段 FROM 表名
select distinct region from REGION;
2、DISTINCT
不显示重复的资料(去重)
语法:SELECT DISTINCT 字段 FROM 表名
select distinct region from REGION;
3、WHERE
有条件查询
语法:SELECT 字段 FROM 表名 WHERE 条件
select site from FARE where money > 1000;
select site from FARE where money < 1000;
select site from FARE where money = 1000;
4、AND、OR
and(并且)、or(或者)
语法:SELECT 字段 FROM 表名 WHERE 条件1 ([AND|OR] 条件2)+;
select site from FARE where money > 1000 and (money < 1500); select site,money from FARE where money < 500 or (money < 1500 and money >= 700); select site,money,date from FARE where money >= 500 and (date < '2021-02-05' and money < 1000);
5、IN
显示已知的值的资料
语法:SELECT 字段 FROM 表名 WHERE 字段 IN (‘值1’,‘值2’,……);
select site,money from FARE where money in (700,1000);
6、BETWEEN
显示两个值范围内的资料
语法:SELECT 字段 FROM 表名 WHERE 字段 BETWEEN ‘值一’ and ‘值二’;
select * from FARE where money between 500 and 1000;
7、通配符、LIKE
通常通配符都是跟LIKE一起使用

LIKE:用于匹配模式来查找资料
语法:SELECT 字段 FROM 表名 WHERE 字段 LIKE ‘模式’;
select * from FARE where site like 'be%';
select site,money from FARE where site like '%jin_';
8、ORDER BY
按关键字排序
语法:SELECT 字段 FROM 表名 [WHERE 条件] ORDER BY 字段 [ASC,DESC];

select * from FARE order by money desc;
select date,money from FARE order by money desc;
9、| | 连接符
- 如果sql_mode开启开启了PIPES_AS_CONCAT,"||"视为字符串的连接操作符而非或运算符,和字符串的拼接函数Concat相类似,这和Oracle数据库使用方法一样的
mysql -uroot -p
use train_ticket; select region || ' ' || site from REGION where region = 'north';
select site || ' ' || money || ' ' || date from FARE;
10、GROUP BY
- BY后面的栏位的查询结果进行汇总分组,通常是结合聚合函数一起使用的
- GROUP BY 有一个原则,就是 SELECT 后面的所有列中,没有使用聚合函数的列,必须出现在GROUP BY后面。
语法:SELECT 字段1,SUM(字段2) FROM 表名 GROUP BY 字段1;
select site,sum(money) from FARE group by site;
select site,sum(money),date from FARE group by site order by money desc;
select site,count(money),sum(money),date from FARE group by site order by money desc;
11、HAVING
- 用来过滤由GROUP BY语句返回的记录集,通常与GROUP BY语句联合使用。
- HAVING语句的存在弥补了WHERE关键字不能与聚合函数联合使用的不足。如果被SELECT的只有函数栏,那就不需要GROUP BY子句。
语法:SELECT 字段1,SUM(字段2) FROM 表名 GROUP BY 字段1 HAVING(函数条件);
select site,count(money),sum(money),date from FARE group by site having sum(money) >=700;
二、函数
1、数学函数

select abs(-1),rand(),mod(5,3),power(2,3),round (1.579),round(1.734,2); select sqrt(9),truncate(1.234,2),ceil(1.2),floor(1.9),greatest(1,2,3,4),least(1,2,3,4);
2、聚合函数

select avg(money) from FARE;
select count(money) from FARE;
select min(money) from FARE;
select max(money) from FARE;
select sum(money) from FARE;
- #count(*)包括所有列的行数,在统计结果时,不好忽略值为null
- #count(字段)只包括那一行的列数,在统计结果的时候,会忽略列值为null的值
3、字符串函数

SELECT TRIM ([ [位置] [要移除的字符串] FROM ] 字符串);
- #[位置]:的值可以为 LEADING (起头), TRAILING (结尾), BOTH (起头及结尾)。
- #[要移除的字符串]:从字串的起头、结尾,或起头及结尾移除的字符串。缺省时为空格。
1 select trim(leading 'na' from 'nanchang');
2 select trim(trailing '--' from 'nanchang--');
3 select trim(both '--' from '--nanchang--');
4
5 select concat(region,site) from REGION where region = 'south';
6 select concat(region,' ',site) from REGION where region = 'south';
7
8 select substr(money,1,2) from FARE;
9
10 select length(site) from FARE;
11
12 select replace(site,'ji','--') from FARE;
13
14 select upper(site) from FARE;
15
16 select lower('HAHAHA');
17
18 select left(site,2) from FARE;
19
20 select right(site,3) from FARE;
21
22 select repeat(site,2) from FARE;
23
24 select space(2);
25
26 select strcmp(100,200);
27
28 select reverse(site) from FARE;
MySQL高级语句(一)的更多相关文章
- MySQL高级语句(二)
目录: 1.别名 2.子查询 3.EXISTS 4.连接查询 5.CREATE VIEW 视图 6.UNION 联集 7.交集值 8.无交集值 9.CASE 10.算排名 11.算中位数 12.算累积 ...
- MySQL高级(进阶)SQL语句
MySQL高级(进阶)SQL语句 目录 MySQL高级(进阶)SQL语句 一.实例准备--制表 1. 表1(商店区域表) 2. 表2(商店销售表) 3. 表3(城市表) 4. 表4(total_sal ...
- 29.MySQL高级SQL语句
MySQL高级SQL语句 目录 MySQL高级SQL语句 创建两个表 SELECT DISTINCT WHERE AND OR IN BETWEEN 通配符 LIKE ORDER BY 函数 数学函数 ...
- MySQL高级特性
MySQL管理 用户管理 CREATE USER username IDENTIFIED BY 'password'; 新建用户 CREATE USER@'%' IDENTIFIED BY 'pass ...
- mysql笔记04 MySQL高级特性
MySQL高级特性 1. 分区表:分区表是一种粗粒度的.简易的索引策略,适用于大数据量的过滤场景.最适合的场景是,在没有合适的索引时,对几个分区进行全表扫描,或者是只有一个分区和索引是热点,而且这个分 ...
- Mysql高级之触发器
原文:Mysql高级之触发器 触发器是一类特殊的事务 ,可以监视某种数据操作(insert/update/delete),并触发相关操作(insert/update/delete). 看以下事件: 完 ...
- Mysql高级之事务
原文:Mysql高级之事务 通俗的说事务: 指一组操作,要么都成功执行,要么都不执行.---->原子性 在所有的操作没有执行完毕之前,其他会话不能够看到中间改变的过程-->隔离性 事务发生 ...
- Mysql高级之游标
原文:Mysql高级之游标 什么是游标?select 语句也许一次性会取出来n条语句,那么游标便可以一次取出来select中的一条记录.每取出来一条,便向下移动一次!可以实现很复杂逻辑! 上面还有有一 ...
- Mysql高级之主从复制
原文:Mysql高级之主从复制 主从复制不就是多台服务器嘛!,一个改变另一个也改变啦,内容其实都一样! 原理: 对数据库进行操作会生成一个文件,binlog(二进制文件),从服务器配置relaylog ...
随机推荐
- 易语言效率与C++究竟差多少(质数和计算)
文本首发bIlibili,cnblogs为作者补发,如在其他平台看见本文,均为经允许的盗窃 易语言作为款主打 中文 易用 编程的开发软件.但是很多人都在批评易语言的效率. 我们今天通过 质数和计算 来 ...
- Java HashMap【笔记】
Java HashMap[笔记] HashMap HashMap 基本结构 HashMap 底层的数据结构主要是数组 + 链表 + 红黑树 其中当链表的长度大于等于 8 时,链表会转化成红黑树,当红黑 ...
- weblogicSSRF漏洞复现
一.关于SSRF 1.1 简介: SSRF(Server-Side Request Forgery)服务端请求伪造,是一种由攻击者构造形成由服务器端发起请求的一个漏洞,一般情况下,SSRF 攻击的目标 ...
- Java异常处理的两种方式以及自定义异常的使用方法
异常 就是程序出现了不正常的情况 Error:严重问题,不需要处理 Exception:称为异常类,他表示程序本身可以处理的问题 RuntimeException:在编译期是不检查的,出现问题后,需要 ...
- SQL 练习3
查询存在" 01 "课程,可能不存在" 02 "课程的情况(不存在时显示为 null ) SELECT * FROM (SELECT * FROM SC WHE ...
- 接入华为应用内支付,验证购买Token接口,返回“rights invalid”
有海外开发者向我们提问:我在应用中集成了华为应用内支付SDK(测试购买订阅型商品),按照文档说明,在服务器去请求验证购买Token接口的时候返回了{"responseCode":& ...
- NOIP 模拟 $12\; \text{简单的区间}$
题解 签到题 求区间和为 \(k\) 的倍数的区间,我们可以转化为求左右两个端点,其前缀和相等 对于区间最大值,我们可以把其转化为一个值,它能向左,向右扩展的最远边界,一个单调栈即可 我们设一个值 \ ...
- SSM自学笔记(五)
10.MyBatis入门操作 1.MyBatis的简介 1.1 原始jdbc操作(查询数据) 1.2 原始jdbc操作(插入数据) ##### 1.3 **原始**jdbc操作的分析 原始jdbc开发 ...
- 遇到的C++ cli 转 C++ native 为C# 程序提供接口。
接口文件 /*++ (do not edit the above line) ************************************************************* ...
- java 内存泄露的几种情况
内存泄漏定义(memory leak):一个不再被程序使用的对象或变量还在内存中占有存储空间. 一次内存泄漏似乎不会有大的影响,但内存泄漏堆积后的后果就是内存溢出.内存溢出 out of memory ...