项目4总结:Mysql数据表的检索

任务4.1

查询时选择列:

1.基本查询语句

MySQL从数据表中查询数据的基本语句为SELECT语句。

2.检索所有列

(1)在SELECT语句中使用星号(*)通配符查询所有字段。其语法格式为:

          SELECT  *  FROM  表名;

(2)在SELECT语句中指定所有字段。其语法格式为:

          SELECT  字段1,字段2,...,字段n  FROM  表名;

3.检索指定字列

(1)检索单个字段。查询表中的某一个字段,其语法格式为:

         SELECT 字段名 FROM 表名;

(2)检索多个字段。其语法格式为:

         SELECT 字段1,字段2,...,字段n FROM 表名;

给字段取别名,其语法格式为:

         字段名  [as]  字段别名;

任务4.2

查询时选择行

1.查询指定记录

在SELECT语句中,通过WHERE子句可以对数据库进行过滤,语法格式为:

SELECT  字段名1,字段名2,...,字段名n  FROM  表名   WHERE  条件;

2.带IN关键字的查询

IN操作符用来指定条件范围,语法格式为:

SELECT  字段名1,字段名2,...,字段名n  FROM   表名  WHERE  字段名  IN(值1,值2,...);

3.带BETWEEN AND 的范围查询

BETWEEN  AND  用来查询某个范围内的值 ,语法格式为:

SELECT  字段名1,字段名2,...,字段n  FROM  表名 WHERE  字段名  BETWEEN 值1 AND 值2;

4.带LIKE的字符匹配查询

执行这个任务的关键字是LIKE,其语法格式为:

SELECT  字段名1,字段名2,...,字段名n  FROM  表名   WHERE  字段名  LIKE  条件

5.查询空值

在SELECT语句中使用IS NULL 子句,可以查询某字段内容为空的记录,其语法格式为:

SELECT  字段名1,字段名2,...,字段名n  FROM  表名   WHERE  字段名  IS  NULL;

6.带AND的多条件查询

可以使用AND连接两个甚至多个查询条件,语法格式为:

SELECT  字段名1,字段名2,...,字段名n  FROM  表名   WHERE  条件1 AND 条件2···;

7.带OR的多条件查询

OR也可以连接两个甚至多个查询条件,语法格式为:

SELECT  字段名1,字段名2,...,字段名n  FROM  表名   WHERE  条件1  OR  条件2···;

8.查询不同的值

可以使用DISTINCT关键字,返回数据的不同值,语法格式为:

SELECT  DISTINCT 字段名1,字段名2,...,字段名n  FROM  表名;

9.显示前N行

可以使用LIMIT关键字,语法格式为:

SELECT  DISTINCT 字段名1,字段名2,...,字段名n  FROM  表名  LIMIT [位置偏移量,]  行数;

任务4.3

查询结果排序

可以使用ORDER BY 语句对查询结果进行排序,其语法格式为:

SELECT  字段名1,字段名2,...,字段名n  FROM  表名  ORDER BY  字段名1[ASC|DESC],字段名2[ASC|DESC]···;

任务4.4

查询分组与汇总

1.聚集函数

(1)AVG() 函数。

(2)COUNT() 函数。

(3)MAX() 函数。

(4)MIN() 函数。

(5)SUM() 函数。

2.分组查询

分组查询是对数据按照某个或多个字段进行分组,其基本语法形式为:

[GROUP  BY  字段名][HAVING<条件表达式>]

3.SELECT子句顺序

下面回顾一下SELECT语句中子句的顺序。

子句说明是否必须使用
SELECT要返回的列或表达式
FROM从中检索数据的表仅在从表中选择数据时使用
WHERE行级过滤
GROUP  BY分组说明仅在按组计算聚集时使用
HAVING组级过滤
ORDER  BY输出顺序排序

任务4.5

创建多表连接查询

1.交叉连接查询

语法格式为:

SELECT  *   FROM  表名1  CROSS  JOIN  表名2;

2.内连接查询

SELECT   查询字段  FROM  表名1 [INNER]  JOIN  表名2  ON  表名1.关系字段=表名2.关系字段;

用户也可以使用WHERE子句来实现多表连接查询,其语法格式为:

SELECT   查询字段  FROM  表名1,表名2,···  WHERE  表名1.关系字段=表名2.关系字段[AND连接条件···];

3.外连接查询

(1) LEFT JOIN (左连接),语法格式为:

SELECT   查询字段  FROM  表名1  LEFT OUTER JOIN  表名2  ON  表名1.关系字段=表名2.关系字段;

(2)RIGHT  JOIN(右连接),语法格式为;

SELECT   查询字段  FROM  表名1  RIGHT OUTER JOIN  表名2  ON  表名1.关系字段=表名2.关系字段;

4.复合条件连接查询

通过添加过滤条件来限制查询的结果,使查询结果更加准确。

5.为表取别名

在Mysql中为表起别名的格式为:

SELECT  *   FROM   表名[AS]  别名;

任务4.6

创建子查询

1.带IN关键字的子查询

SELECT 语句中可以使用NOT IN关键字,其语法格式为:

SELECT 查询字段  FROM  表名  WHERE 字段名  [NOT] IN (SELECT语句);

2.带EXISTS关键字的子查询

EXISTS关键字后面的参数是一个任意的子查询,其语法格式为:

SELECT 查询字段  FROM  表名  WHERE 字段名  [NOT]  EXISTS (SELECT语句);

3.带ANY、SOME关键字的子查询

ANY和SOME关键字是同义字,表示满足其中任意一条件,其语法格式为:

SELECT 查询字段  FROM  表名  WHERE 字段名   比较运算符  ANY|SKOME  (SELECT语句);

4.带ALL关键字的子查询

使用ALL时需要同时满足所有内层查询的条件,其语法格式为:

SELECT 查询字段  FROM  表名  WHERE 字段名  比较运算符  ALL  (SELECT语句);

任务4.7

创建多表联合查询

1.使用UNION

其语法格式为:

SELECT  查询字段  FROM   表名

UNION [ALL]

CELECT  查询字段  FROM  表名;

2.UNION规则

(1)UNION必须由两条或两条以上的SELECT语句组成,语句之间用关键字UNION分隔。

(2)UNION中的每个查询必须包含相同的列,表达式或聚集函数

(3)列数据类型必须兼容:类型不必完全相同,但必须是DBMS可以隐式转换的类型

3.包含或取消重复的行

UNION从查询结果集中自动去除重复的行

4.对联合查询结果排序

SELECT语句可以使用ORDER  BY 子句排序

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值