前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >select 查询基础

select 查询基础

作者头像
Demo_Null
发布2020-09-28 17:40:26
7780
发布2020-09-28 17:40:26
举报
文章被收录于专栏:Java 学习

1.1 基础查询

1.1.1 查询所有列

语法

代码语言:javascript
复制
# " * " 代表返回表中所有字段的数据
select * from tb_name;

示例

代码语言:javascript
复制
mysql> select *  from student;
+------+--------+------+
| num  | name   | age  |
+------+--------+------+
|    2 | 李娜扎 |   33 |
|    3 | 王大锤 |  700 |
|    4 | 牛魔王 | 1000 |
+------+--------+------+  
3 rows in set (0.04 sec)        

注意

  如果不查询表中所有的列,尽量避免使用 SELECT *,因为它会进行全表扫描,不能有效利用索引,增大了数据库服务器的负担,以及它与应用程序客户端之间的网络 IO 开销。

1.1.2 查询指定字段

语法

代码语言:javascript
复制
# tb_name 表中需要查询的字段
select field_1, field_2 from tb_name;

示例

代码语言:javascript
复制
mysql> select name, age from student;
+--------+------+
| name   | age  |
+--------+------+
| 李娜扎 |   33 |
| 王大锤 |  700 |
| 牛魔王 | 1000 |
+--------+------+
3 rows in set (0.04 sec)

1.1.3 别名

  在创建数据表时,一般都会使用英文单词或英文单词缩写来设置字段名,在查询时列名都会以英文的形式显示,我们可以给列名起别名,增强阅读性。

语法

代码语言:javascript
复制
# 用中文名代替字段名,其中 as 可以省略
select col_name [as] chinese_name from tb_name;

示例

代码语言:javascript
复制
mysql> select num as '序号', age '年龄' from student;
+------+------+
| 序号 | 年龄 |
+------+------+
|    2 |   33 |
|    3 |  700 |
|    4 | 1000 |
+------+------+
3 rows in set (0.04 sec)

注意

  ① 别名可以使用引号引起来(单双皆可),也可以不使用。   ② 别名中有特殊符号的,比如空格,此时别名必须用引号引起来。   ③ 尽量不要省略 as,方便阅读。

1.2 条件查询

1.2.1 语法

代码语言:javascript
复制
# 条件查询
select * from 表名 where 条件;

注意

  关键字 where 后面跟上一个或者多个条件,条件是对前面数据的过滤,只有满足 where 后面条件的数据才会被返回。

1.2.2 运算符

符号

描述

备注

=

等于

<>, !=

不等于

不推荐使用 !=

>

大于

<

小于

<=

小于等于

>=

大于等于

BETWEEN AND

在两值之间

>= min && <= max

NOT BETWEEN AND

不在两值之间

IN

在集合中

IN 后面括号中可以包含多个值,对应记录的字段满足集合中任意一个都会被返回

NOT IN

不在集合中

<=>

严格比较两个 NULL 值是否相等

两个操作码均为 NULL 时,其所得值为 1;而当一个操作码为 NULL 时,其所得值为 0

LIKE

模糊匹配

%:表示匹配任意一个或多个字符_:表示匹配任意一个字符。

REGEXP 或 RLIKE

正则式匹配

IS NULL

为空

IS NOT NULL

不为空

AND

多个条件都成立

OR

多个条件中满足一个

注意

 ① 空值查询需要使用 IS NULL 或者 IS NOT NULL,其他查询运算符对 NULL 值无效  ② 建议创建表的时候,尽量设置表的字段不能为空,给字段设置一个默认值。  ③ LIKE 中的 % 可以匹配一个到多个任意的字符,_ 可以匹配任意一个字符,需要使用引号整体引起来。  ④ <=> 既可以判断 NULL 值,又可以判断普通的数值,但可读性较低,不推荐使用。

1.2.3 示例

==、<>

代码语言:javascript
复制
mysql> select num as '序号', age '年龄' from student where num = 3;
+------+------+
| 序号 | 年龄 |
+------+------+
|    3 |  700 |
+------+------+
1 row in set (0.03 sec)

mysql> select num as '序号', age '年龄' from student where num <> 3;
+------+------+
| 序号 | 年龄 |
+------+------+
|    2 |   33 |
|    4 | 1000 |
+------+------+
2 rows in set (0.04 sec)

BETWEEN AND

代码语言:javascript
复制
mysql> select num as '序号', age '年龄' from student where age between 700 and 1000;
+------+------+
| 序号 | 年龄 |
+------+------+
|    3 |  700 |
|    4 | 1000 |
+------+------+
2 rows in set (0.03 sec)

IN

代码语言:javascript
复制
mysql> select num as '序号', age '年龄' from student where age in (700, 800, 900, 1000);
+------+------+
| 序号 | 年龄 |
+------+------+
|    3 |  700 |
|    4 | 1000 |
+------+------+
2 rows in set (0.03 sec)

LIKE

代码语言:javascript
复制
mysql> select num as '序号', name as '姓名', age as '年龄' from student where name like '%唐%';
+------+-----------+------+
| 序号 | 姓名       | 年龄 |
+------+-----------+------+
|    2 | 李娜扎·唐  |   33 |
+------+-----------+------+
1 row in set (0.04 sec)

IS NULL、IS NOT NULL

代码语言:javascript
复制
mysql> select * from student;
+------+----------+------+
| num  | name     | age  |
+------+----------+------+
|    2 | 李娜扎·唐 |   33 |
|    3 | 王锤锤·明 |  700 |
|    4 | NULL     | 1000 |
+------+----------+------+
3 rows in set (0.03 sec)

mysql> select num as '序号', name as '姓名', age as '年龄' from student where name is null;
+------+------+------+
| 序号 | 姓名 | 年龄 |
+------+------+------+
|    4 | NULL | 1000 |
+------+------+------+
1 row in set (0.04 sec)

mysql> select num as '序号', name as '姓名', age as '年龄' from student where name is not null;
+------+----------+------+
| 序号 | 姓名      | 年龄 |
+------+----------+------+
|    2 | 李娜扎·唐 |   33 |
|    3 | 王锤锤·明 |  700 |
+------+----------+------+
2 rows in set (0.03 sec)
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/07/01 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.1.1 查询所有列
  • 1.1.2 查询指定字段
  • 1.1.3 别名
  • 1.2 条件查询
    • 1.2.1 语法
      • 1.2.2 运算符
        • 1.2.3 示例
        相关产品与服务
        数据库
        云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档