Linux运维数据库篇 MySQL高阶语句的应用 1

一、添加表和数据

mysql> create table text1(id int(10),name varchar(20),type varchar(20));
Query OK, 0 rows affected (0.01 sec)
mysql> create table text2(id int(10),name varchar(20),type varchar(20),money int(10));
Query OK, 0 rows affected (0.01 sec)
mysql> insert into text1 values(1,'sky-lake','LGA1151');
Query OK, 1 row affected (0.01 sec)

mysql> insert into text1 values(2,'kober-lake','LGA1151');
Query OK, 1 row affected (0.00 sec)
mysql> insert into text1 values(3,'coffiee-lake','LGA1151');
Query OK, 1 row affected (0.00 sec)
mysql> insert into text2 values(1,'fx','am4','2014');
Query OK, 1 row affected (0.00 sec)
mysql> insert into text2 values(2,'zen1','am4','2017');
Query OK, 1 row affected (0.01 sec)

mysql> insert into text2 values(3,'zen+','am4','2018');
Query OK, 1 row affected (0.00 sec)
mysql> insert into text2 values(3,'zen2','am4','2019');
Query OK, 1 row affected (0.00 sec)

表结构
在这里插入图片描述
查看数据

mysql> select * from text1;

在这里插入图片描述

mysql> select * from text2;

在这里插入图片描述

二、语句

1.select 查询排序(升降序)

降序

语法 asc为升序 MySQL默认排序的就是升序 besc为降序

select * from 表名 order by 要排序的字段 asc/besc

实例

mysql> select * from text1 order by id desc;

在这里插入图片描述

升序

asc可以不写 默认为升序

mysql> select * from text1 order by id asc;

在这里插入图片描述

多字段排序

对每个字段进行不同的升降序操作
语法

select 要排序的字段(两个) from 表名 order by 要升序的字段,要降序的字段 

实例
在这里插入图片描述

嵌套查找

也可以嵌套/多条件查找 where用于判断条件

select * from 表名 where 要查询的字段 >1 or (字段名 >100 and 字段名 <500);

在这里插入图片描述

2.select筛重

用于筛查表格中的重复的字段
distinct必须放在开头
distinct只能使用需要去重的字段进行操作
distinct去重多个字段时,含义是:几个字段同时重复时才会会被过滤

select distinct 字段名 from 表名;

在这里插入图片描述

3 对结果分组

对查询的结果,还可以对其进行分组,使用group by 来进行分组 结合聚合函数一起使用,例如 计数(count),平均数(avg) ,最大值(max),最小值(min),求和(sum)。 可以按一个字段和多个字段对结果进行分组处理

 select year,count(id) as sum from text1 where year>1000 group by year;

在这里插入图片描述
可以结合order by对结果来进行升降序操作

select year,count(id) as sum from text1 where year>1000 group by year order by year desc;;

在这里插入图片描述

4 限制条目结果

select返回的数据是返所有的数据 有时仅需要其中的某几行的数据 可以使用limit字句来实现
同样可以结合order by来进行结果的排序

select * from 表名 limit 索引下标,下标之后的位置

在这里插入图片描述

5 设置别名

和Linux的别名用途一致 对长的列名和表名来设置一个别名方便书写 在查询时 表内的列的名称不会改变

select 字段 as 别名 from 表名; 设置列的别名
select i 字段名 as 别名 from 表名; 设置表数据设置别名

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

6 通配符

主要用于替换字符换中的部分字符,通过部分字符的匹配将相关结果查询出来
和like一起使用,结合wherer字句共同来完成查询任务‘
%:表示零个 一个和多个字符
_:表示单个字符开头

select * from 表名 where type like '要查的关键字的条件';

在这里插入图片描述
在这里插入图片描述

总结

1升降序采用在语句末尾加上asc desc asc为默认 order by’ 对多个字段排序后可以将数个数据排序
2select语句加上where嵌套查询语句
3采用distinct筛重,distinct必须放在开头,distinct只能使用需要去重的字段进行操作,distinct去重多个字段时,含义是:几个字段同时重复时才会会被过滤
4group by+函数结合别名和where判断对查询的数据来分组 同时进行排序操作
5limit字句实现限制查询的结果的多少 可以结合ordry by来进行排序操作
6通配符+like结合where来根据条件查询数据

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值