MySql的基础知识之select

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: MySql的基础知识之select 一、select语法 1、 简单查询语句 select 字段 from 表名|视图 where 条件 order by 字段 desc|asc (|表示或,desc降序,asc升序,不写默认升序) 例如 : select * from user where n.

MySql的基础知识之select

一、select语法

1、 简单查询语句

select 字段 from 表名|视图 where 条件 order by 字段 desc|asc (|表示或,desc降序,asc升序,不写默认升序)
例如 :

select * from user where name='张三' order by id; (*表示所有字段)
另:select  id, name,sex,phone from user where name='张三' order by id;

2、 查询不重复的数据

select distinct 字段[,字段,字段...] from 表名; 一个字段就判断一个字段的重复值,多个就会组合判断,多个都重复才会认为重复;
例如:

select  distinct name from user;  查出所有用户的名字;

3、 显示指定条数的数据

sql最后加 limit 起始偏移量,行数。第一个表示从第多少条开始,第二个表示取出来多少条,如取根据用户的创建时间,取最新的10条数据

select * from user order by createTime desc limit 1,10;

二、select 常见示例

1、控制流程

我们经常会遇见需要对字段的显示进行处理的情况,如性别字段值1显示男,值2显示女。

(1)case;

语法为 case 字段 when 值 then '' when 值 then '' ...... else '' end as 别名 (else 可不用)
例如:

select name ,case sex when 1 then '男' when 2 then '女' end as s from user ;

还有另一种情况,简单的值判断无法满足需求,如年龄18以下显示未成年,18-50显示青年,50以上显示老年,这时候需要表达式来进行判断;
语法为case when 表达式 then '' when 表达式 then ''...... else '' end as 别名
例如:

select name ,
       case when age<18 then '未成年'  
       when age between 18 and 50 then '青年' 
       when age>50 then '老年' end a 
from user; 

表达式可以是一个也可以是多个,如未满18的女性显示美少女,就是when age<18 and sex=2 then '美少女'。

(2)IF;

IF (expr1,expr2,expr3) 如果 expr1 是TRUE (expr1 <> 0 and expr1 <> NULL),则 IF()的返回值为expr2; 否则返回值则为 expr3。IF() 的返回值为数字值或字符串值,具体情况视其所在语境而定

 SELECT IF(1>2,2,3);返回3
 SELECT IF(1<2,'yes ','no');返回yes
 SELECT IF(STRCMP('test','test1'),'no','yes');返回no

(3)STRCMP;

Strcmp(str1,str2):如果str1>str2返回1,str1=str2反回0,str1<str2返回-1
如果字符串相同,STRCMP()返回0,如果第一参数根据当前的排序次序小于第二个,返回-1,否则返回1。

 select STRCMP('text', 'text2'); 返回-1
 select STRCMP('text2', 'text'); 返回1
 select STRCMP('text', 'text');返回0

2、函数

这里只说明一下常用的函数,如下:

(1)IFNULL

判断是否为空,如果有值返回该字段的值,为空则返回指定值,语法为IFNULL(字段,'')
例如:

select name,ifnull(age,'该用户未填写年龄') from user 

(2)CONCAT

字符串连接,数据库中不能用+号连接字符串,语法为CONCAT(str1,str2,...)
例如:

select CONCAT(name,'是一个',age,'的',case sex when 1 then '男' when 2 then '女' end ,'生') 
from user;

但是有一点需要特别说明,如果其中一个字段为Null,则返回为null,因此,假如有某列数据可能会空的,字段用ifnull(age,'')

(3)FORMAT

对字段进行格式化,FORMAT(x,n)函数可以将数字x进行格式化,将x保留到小数点后n位。这个过程需要进行四舍五入。例如FORMAT(2.356,2)返回的结果将会是2.36;FORMAT(2.353,2)返回的结果将会是2.35。

(4) INET_ATON

INET_ATON(IP)函数可以将IP地址转换为数字表示,数字比字符串存储空间少,查询效率高,这算是一种mysql的优化;INET_NTOA(n)函数可以将数字n转换成IP的形式。其中,INET_ATON(IP)函数中IP值需要加上引号。这两个函数互为反函数。


数据库中对字符串、日期、数字的函数比较多,会单独写文章说明。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
6月前
|
关系型数据库 MySQL
【MySQL】——Select查询语句知识点练习(其一)
【MySQL】——Select查询语句知识点练习(其一)
|
6月前
|
SQL 关系型数据库 MySQL
在云数据仓库AnalyticDB MySQL版中,有几个参数可能影响SELECT查询的执行及其稳定性
在云数据仓库AnalyticDB MySQL版中,有几个参数可能影响SELECT查询的执行及其稳定性【1月更文挑战第16天】【1月更文挑战第80篇】
341 4
|
6月前
|
SQL 关系型数据库 MySQL
【MySQL】— —熟练掌握用SQL语句实现数据库和基本表的创建。熟练掌握MySQL的安装、客户端登录方法;熟练掌握MySQL的编码、数据类型等基础知识;掌握实体完整性的定义和维护方法、掌握参照完整性
【MySQL】— —熟练掌握用SQL语句实现数据库和基本表的创建。熟练掌握MySQL的安装、客户端登录方法;熟练掌握MySQL的编码、数据类型等基础知识;掌握实体完整性的定义和维护方法、掌握参照完整性
|
6月前
|
SQL 关系型数据库 MySQL
MySQL技能完整学习列表3、SQL语言基础——1、SQL(Structured Query Language)简介——2、基本SQL语句:SELECT、INSERT、UPDATE、DELETE
MySQL技能完整学习列表3、SQL语言基础——1、SQL(Structured Query Language)简介——2、基本SQL语句:SELECT、INSERT、UPDATE、DELETE
116 0
|
4天前
|
SQL NoSQL 关系型数据库
2024Mysql And Redis基础与进阶操作系列(5)作者——LJS[含MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页等详解步骤及常见报错问题所对应的解决方法]
MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页、INSERT INTO SELECT / FROM查询结合精例等详解步骤及常见报错问题所对应的解决方法
|
5月前
|
存储 SQL 关系型数据库
MySQL基础知识
【6月更文挑战第13天】MySQL基础知识
49 7
|
3月前
|
存储 关系型数据库 MySQL
在 MySQL 中使用 Insert Into Select
【8月更文挑战第11天】
436 0
在 MySQL 中使用 Insert Into Select
|
4月前
|
存储 关系型数据库 文件存储
面试题MySQL问题之简单的SELECT操作在MVCC下加锁如何解决
面试题MySQL问题之简单的SELECT操作在MVCC下加锁如何解决
46 2
|
5月前
|
关系型数据库 MySQL Linux
MySQL数据库基础知识
【6月更文挑战第20天】MySQL数据库基础知识。
63 3
|
6月前
|
SQL 关系型数据库 MySQL
MySQL技能完整学习列表10、数据导入和导出——1、数据导入(LOAD DATA, mysqldump)——2、数据导出(SELECT ... INTO OUTFILE, mysqldump)
MySQL技能完整学习列表10、数据导入和导出——1、数据导入(LOAD DATA, mysqldump)——2、数据导出(SELECT ... INTO OUTFILE, mysqldump)
115 0

推荐镜像

更多