目录

第1关 基本查询语句

一、本关任务:

查询数据表中指定字段的内容

二、编程要求

三、代码 

第2关 带IN关键字的查询

一、本关任务:使用IN关键字检索数据表中指定的数据内容。

带IN关键字的查询

带NOT IN关键字的查询

三、预期输出

四、代码 

第3关 带BETWEEN AND的范围查询

一、本关任务:使用BETWEEN AND关键字检索数据表中指定的数据内容。

带BETWEEN AND关键字的查询

二、编程要求

三、预期输出

 四、代码


第1关 基本查询语句

一、本关任务:

  • SELECT语句检索数据表中指定字段的数据;

  • SELECT语句检索数据表中所有字段的数据。

查询数据表中指定字段的内容

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

SELECT语句的可选参数比较多,让我们先从最简单的开始,带大家一步一步的深入SELECT语句的使用。

SELECT 基本语法规则为: SELECT 字段名 FROM 表名; 。

举个例子
假设我们现在有一张表Mall_products,内容如下:

我们需要从数据表中查询所有商品的名称,你们想想该怎么写?

查询代码如下:



  1. SELECT prod_name
  2. FROM Mall_products;

结果为:

查询过程如下:

分析:

在该例子中,我们使用了SELECT语句从Mall_products表中获取名称为prod_name字段下的所有产品名称,字段名称需要紧跟在SELECT关键字之后。

然而事实上,我们查询数据的时候,往往需要同时查询多个字段下的内容。这时,我们只需要在字段之间加入逗号,即可。

语法规则为: SELECT 字段名1, 字段名2 FROM 表名; 。

举个例子
假设我们现在有一张表Mall_products,内容与上例相同。我们需要从数据表中查询所有商品的名称和价格,你们想想该怎么写?

查询代码如下:



  1. SELECT prod_name, prod_price
  2. FROM Mall_products;

结果为:

小提示: MySQL 中的 SQL 语句对关键字的大小写不敏感, SELECT 和 select 是一样的。 但是许多开发者更喜欢将关键字大写,表名和字段名使用小写,养成这种习惯,以后写出来的脚本就更容易阅读和维护了。

查询数据表中的所有内容

如果我们不记得字段名字了,我们还可以查看整张表的内容。这时候,只需要我们用星号*来代替字段的名字,就会得到一整张表的内容。

语法规则为: `SELECT *` `FROM 表名;`

举个例子
假设我们现在有一张表Mall_products。一开始我们并不知道表里都有什么,所以想要查看整张数据表的内容,你们想想该怎么写?

查询代码如下:



  1. SELECT *
  2. FROM Mall_products;

结果为:

小提示: 虽然使用星号 * 看起来是一件很方便的事情,但是建议大家在不想获取整张表的情况下,还是使用字段名来进行查询。因为很显然,它会降低查询的效率。

二、编程要求

一个数据表tb_emp,结构如下:

  • 请你查询字段NameSalary的内容;

  • 请你查询整张表的内容。

三、代码 

USE Company;

########## Begin ##########

########## retrieving the Name and Salary ##########


########## retrieving all the table ##########


########## End ##########

第2关 带IN关键字的查询

一、本关任务:使用IN关键字检索数据表中指定的数据内容。

IN关键字的查询

IN关键字被用在WHERE语句的后边,用来过滤你所需要查询的内容。更形象的说,IN关键字的使用情形就像点名,点到谁谁就要站出来。

语法规则为: SELECT 字段名 FROM 表名 WHERE 字段名 IN (n1,n2,n3,...); 。

其中,括号内的数字必须为INT格式的数字。被“点到名”的这些括号里数字对应的内容,都要乖乖的站到前边来展示给大家看。

举个例子
假设我们现在有一张表Mall_products,内容如下:

我们会使用IN关键字检索出所有国家代码为18639的商品信息。

查询代码如下:



  1. SELECT *
  2. FROM Mall_products
  3. WHERE prod_country IN (1,87,39);

结果为:

查询过程如下:

Oopes! 貌似我们刚才输入了三个数字,为什么只查询到了国家代码为139的数据内容,87去哪里了?

因为国家代号87的内容就压根没存在过啊,仔细看看表Mall_products就知道了。

NOT IN关键字的查询

聪明的小伙伴一看NOT就知道了,我们是要取反了。刚才我们是在查询括号中出现的内容,加了NOT取反后,就意味着,我们要查询的是除了括号中出现内容外的所有内容。

语法规则为: SELECT 字段名 FROM 表名 WHERE 字段名 NOT IN (n1,n2,n3,...); 。

举个例子
我们还使用刚才的表Mall_products。现在我们想要查询除了国家代码为86的所有国家的产品内容。

查询代码如下:



  1. SELECT *
  2. FROM Mall_products
  3. WHERE prod_country NOT IN (86);

结果为:

二、编程要求

一个数据表tb_emp,结构如下:

  • 请你查询当Id不等于1时,字段NameSalary的内容;

三、预期输出

四、代码 

USE Company;

########## Begin ##########

########## retrieving the Name and Salary with IN statement ##########
select Name,Salary FROM tb_emp where Id NOT IN(1);


########## End ##########

第3关 带BETWEEN AND的范围查询

一、本关任务:使用BETWEEN AND关键字检索数据表中指定的数据内容。

BETWEEN AND关键字的查询

BETWEEN AND需要两个参数支持,一个是范围的开始值,另一个就是结束值了。如果字段值满足指定的范围查询条件,就返回这些满足条件的数据内容。

语法规则为: SELECT 字段名 FROM 表名 WHERE 字段名 BETWEEN n1 AND n2; 。

举个例子
假设我们现在有一张表Mall_products,内容如下:

我们将使用BETWEEN AND关键字检索出所有国家代码为1~50的商品的信息。

查询代码如下:



  1. SELECT *
  2. FROM Mall_products
  3. WHERE prod_country BETWEEN 1 AND 50;

结果为:

查询过程如下:

可以看到,返回结果包含了国家代码从1~50之间的字段值。尤其值得注意的是,端点值1也包含在返回结果中。

NOT BETWEEN AND关键字的查询

像上一关介绍的关键字IN一样,我们还可以对关键字BETWEEN AND进行取反,表示查询指定范围之外的值。

语法规则为: SELECT 字段名 FROM 表名 WHERE 字段名 NOT BETWEEN n1 AND n2; 。

举个例子
我们依然使用表Mall_products。现在我们想要查询除了国家代码为1~50的所有国家的产品内容。

查询代码如下:



  1. SELECT *
  2. FROM Mall_products
  3. WHERE prod_country NOT BETWEEN 1 AND 50;

结果为:

由结果可以看出,返回的结果只有大于国家代码50的内容。

二、编程要求

一个数据表tb_emp,结构如下:

  • 请你查询当字段Salary范围在3000~5000时,字段NameSalary的内容。

三、预期输出

 四、代码

USE Company;

########## Begin ##########

########## retrieving the Name and Salary with BETWEEN AND statement ##########

SELECT Name,Salary FROM tb_emp WHERE Salary BETWEEN 3000 AND 5000;
########## End ##########

Logo

腾讯云面向开发者汇聚海量精品云计算使用和开发经验,营造开放的云计算技术生态圈。

更多推荐