【MySQL进阶之路 | 基础篇】基本的SELECT语句及DESC显示表结构

1. SELECT ...

例 : 

fb97c00ac5cd40b785ccc2133ed53214.png

2. SELECT ... FROM ...

(1). SELECT ... : 标识选择哪些列.

(2). FROM ... : 标识从哪个表中选取.

(3). *通配符 : 选择表中全部列.

例 : 

1b88fc228b16470c86dde07c42975510.png

7b64fe82a4e94757b2829155202f8277.png

3.列的别名

(1). 空一格.

(2). 在列和别名间加入关键字AS.

(3). 别名可以使用双引号,以便于在别名中包含空格或特殊的字符并区分大小写.

1f8e4cd3083b4022a3802e9bd24e361a.png

4. 去除重复行

使用DISTINCT关键字.

本来有107条记录,去除掉重复的firstname后,剩余91条记录.

3a2ccac146d8468986e5d3fa53c2d98e.png

SELECT DISTINCT first_name, last_name
FROM employees;

将删除该表中first_name, last_name都相同的记录.

5.空值参加运算

所有运算符或列值遇到null,其运算结构都为null.

在MySQL中,空值并不等同于空字符串.一个空字符串的长度为0,而一个空值的长度为空.在MySQL中,空值是占用空间的.

IFNULL(expression, value_if_null) : 如果expression是null,那么该空值将被value_if_null指定值替代.

6. 着重号

# 存在有这么一个表order
SELECT * 
FROM order;
# 将会报错, 大小写不敏感, order被视作ORDER关键字, 所以会报错
# 加上着重号引起来即可.
SELECT * 
FROM `order`;
# 正确的写法

7.查询常数

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

f6bd58c791124d25a3247e809c795850.png

8.显示表结构

我们可以使用DSECRIBE/DESC 表名

来显示表结构.

例 : 

1c759f8fcebf47dcb18c9e53df3083d2.png

注 : 

其中,各个字段的含义分别解释如下:

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

9.过滤数据(WHERE)

我们可以使用WHERE子句过滤不满足条件的行.WHERE子句紧跟FROM子句.

例 : 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值