MySQL_03:基本的SELECT语句

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: MySQL_03:基本的SELECT语句

@[toc]

基本的SELECT语句

  • SELECT...
SELECT 2*2;
SELECT 9/2; #没有任何子句
  • SELECT ... FROM
SELECT 标识选择哪些列
FROM 标识从哪个表中选择
  • 选择全部列和查询某列
# *:表中所有的字段(或列)
SELECT * FROM  countries;
# 查询某列
SELECT country_id
FROM countries;

注意:一般情况下,除非需要使用表中所有的字段数据,最好不要使用通配符‘ ’。使用通配符虽然可以节 省输入查询语句的时间,但是获取不需要的列数据通常会降低查询和所使用的应用程序的效率。通 配符的优势是,当不知道所需要的列的名称时,可以通过它获取它们。 在生产环境下,不推荐你直接使用 SELECT 进行查询。

列的别名

  • 重命名一个列
  • 便于计算
  • 紧跟列名,也可以在列名和别名之间加入关键字AS,别名使用双引号,以便在别名中包含空格或特殊的字符并区分大小写。
  • AS 可以省略
  • 建议别名简短,见名知意
  • 举例
SELECT country_id,country_name
FROM countries;

在这里插入图片描述

# 列的别名:
SELECT country_id emp_id,country_name AS emp_name,region_id "第三列"
FROM countries;

在这里插入图片描述

注意:第三种方式加双引号是可以去掉的,但是某些情况不可以,比如当名字中间有空格的时候

# 列的别名:(这么写就会报错)
SELECT country_id emp_id,country_name AS emp_name,region_id 第 三列
FROM countries;

去除重复行

使用场景举例:比如某表里面有很多员工,员工对应了职位,把所有职位去重,就看见了总共有那些职位

#未去重
SELECT   department_id
FROM employees;
#去重
SELECT  DISTINCT department_id
FROM employees;
  • DISTINCT 需要放到所有列名的前面,如果写成 SELECT salary, DISTINCT department_id FROM employees 会报错。

错误举例

第一种:去重部分

SELECT  salaru,DISTINCT department_id
FROM employees;

解释:会报错,前面不去重后面去重,没法实现

第二种:整体去重

SELECT  DISTINCT department_id,salaru
FROM employees;

解释:不会报错,但是毫无意义,查重是去除的是两个列的元素整体来看不同的

空值(null)

  • null不等同于0、‘ ’、‘null’
  • null参与运算,结果也一定为null

举例:这里部分员工的年工资变成了null,因为null不等于,只要参与了运算,结果就为null

在这里插入图片描述

着重号

命名规则有说到:必须保证你的字段没有和保留字、数据库系统或常用方法冲突。如果坚持使用,请在SQL语句中使 用`(着重号)引起来

在这里插入图片描述

解释:这里的order表和关键字重名了,所以需要用着重号,不然会报错

查询常数

SELECT 查询还可以对常数进行查询。就是在 SELECT 查询结果中增加一列固定的常数列。这列的 取值是我们指定的,而不是从数据表中动态取出的。 你可能会问为什么我们还要对常数进行查询呢? SQL 中的 SELECT 语法的确提供了这个功能,一般来说我们只从一个表中查询数据,通常不需要增加一个 固定的常数列,但如果我们想整合不同的数据源,用常数列作为这个表的标记,就需要查询常数。 比如说,我们想对 employees 数据表中的员工姓名进行查询,同时增加一列字段员工所属公司 ,这个 字段固定值为“华为员工”,可以这样写:

SELECT '华为员工' as '员工所属公司', last_name FROM employees;

在这里插入图片描述

显示表结构

  • 使用DESCRIBE 或 DESC 命令,表示表结构
  • 这里用命令行演示不用navicat

在这里插入图片描述

  • Field:表示字段名称。
  • Type:表示字段类型,这里 barcode、goodsname 是文本型的,price 是整数类型的。
  • Null:表示该列是否可以存储NULL值。
  • Key:表示该列是否已编制索引。PRI表示该列是表主键的一部分;UNI表示该列是UNIQUE索引的一 部分;MUL表示在列中某个给定值允许出现多次。
  • Default:表示该列是否有默认值,如果有,那么值是多少。
  • Extra:表示可以获取的与给定列有关的附加信息,例如AUTO_INCREMENT等。

过滤数据

使用场景:比如返回某公司员工工资一栏达到5000以上的人员、某企业年收入过百万的部门等等筛选

语法:

SELECT 字段1,字段2
FROM 表名
WHERE 过滤条件

举例:找出下列表种salary大于5000的员工姓名

在这里插入图片描述

代码:

SELECT first_name '姓名',salary '工资'
FROM employees
WHERE salary >'5000';

在这里插入图片描述
注意:WHERE必须放在FROM后面

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
5月前
|
关系型数据库 MySQL
【MySQL】——Select查询语句知识点练习(其一)
【MySQL】——Select查询语句知识点练习(其一)
|
5月前
|
SQL 关系型数据库 MySQL
在云数据仓库AnalyticDB MySQL版中,有几个参数可能影响SELECT查询的执行及其稳定性
在云数据仓库AnalyticDB MySQL版中,有几个参数可能影响SELECT查询的执行及其稳定性【1月更文挑战第16天】【1月更文挑战第80篇】
328 4
|
5月前
|
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
112 0
|
2月前
|
存储 关系型数据库 MySQL
在 MySQL 中使用 Insert Into Select
【8月更文挑战第11天】
153 0
在 MySQL 中使用 Insert Into Select
|
3月前
|
存储 关系型数据库 文件存储
面试题MySQL问题之简单的SELECT操作在MVCC下加锁如何解决
面试题MySQL问题之简单的SELECT操作在MVCC下加锁如何解决
40 2
|
5月前
|
SQL 关系型数据库 MySQL
MySQL技能完整学习列表10、数据导入和导出——1、数据导入(LOAD DATA, mysqldump)——2、数据导出(SELECT ... INTO OUTFILE, mysqldump)
MySQL技能完整学习列表10、数据导入和导出——1、数据导入(LOAD DATA, mysqldump)——2、数据导出(SELECT ... INTO OUTFILE, mysqldump)
103 0
|
3月前
|
关系型数据库 MySQL 索引
MySQL之优化SELECT语句
以上只是一些基本的优化策略,具体的优化方案还需要根据实际的业务需求和数据情况来定制。
38 0
|
4月前
|
关系型数据库 MySQL Linux
mysql 将select结果导出文件 linux
mysql 将select结果导出文件 linux
50 3
|
4月前
|
关系型数据库 MySQL 数据库
MySQL SELECT查询实战:练习题精选,提升你的数据库查询技能
MySQL SELECT查询实战:练习题精选,提升你的数据库查询技能
|
4月前
|
SQL 关系型数据库 MySQL
深入探索MySQL SELECT查询:从基础到高级,解锁数据宝藏的密钥
深入探索MySQL SELECT查询:从基础到高级,解锁数据宝藏的密钥
下一篇
无影云桌面