SELECT查询语句

数据查询是数据库的核心操作,其功能是指根据用户的需要从数据库中提取所需数据,通过SQL的数据操纵语言的SELECT语句可以实现数据库数据的查询。

SELECT语句是SQL中用途最广泛的一条语句,具有灵活的使用方式和丰富的功能。  

从指定的基本表或视图中,选择满足条件的元组数据,并对它们进行分组、统计、排序和投影,形成查询结果集。

  说明:

  SELECT和FROM语句为必选子句,而其他子句为可选子句。INTO <新表>用于指定使用结果集来创建新表,<新表>指定新表的名称。

SELECT语法格式:

  一个完整的SELECT语句包括SELECT、FROM、WHERE、GROUP BY和ORDER BY子句,SELECT语句具有数据查询、统计、分组和排序的功能。它的语法及各子句的功能如下。

SELECT [ALL︱DISTINCT][TOP n][<目标字段表达式>[,…n]]
[INTO <新表>]
FROM <表名或视图名>[,<表名或视图名>[…n]]
WHERE <条件表达式>]
GROUP BY <字段名l>[HAVING <条件表达式>]]
ORDER BY <字段名2>[ASC︱DESC]];

功能:     

  从指定的基本表或视图中,选择满足条件的元组数据,并对它们进行分组、统计、排序和投影,形成查询结果集。

说明:

  SELECT和FROM语句为必选子句,而其他子句为可选子句,根据要求选用。

  INTO <新表>用于指定使用结果集来创建新表,也即重新创建一张新表,新表的内容从SELECT语句结果组,<新表>指定新表的名称。

SELECT语句的执行

  在SQL Server2016中,通过使用SSMS提供的查询编辑器,可以编辑和运行查询代码。

SELECT基本子句用于指定返回数据表中的简单列值,

其语法格式如下:

  SELECT [ALL︱DISTINCT][TOP n][<目标字段表达式>[,…n]]

作用:

该子句用于指明查询结果集的目标字段,<目标字段表达式>是指查询结果集中包含的字段名,可以是直接从基本表或视图中投影得到的字段,也可以是与字段相关的表达式或数据统计的函数表达式,目标字段还可以是常量。其中:

  • DISTINCT说明要去掉重复的元组
  • ALL表示所有满足条件的元组
  • TOP 表示只显示结果集的前多少行,n是对行数的说明。
  • 省略<目标字段表达式>表示结果集中包含<表名或视图名>中的所有字段,此时<目标字段表达式>使用“*”代替

如果目标字段中使用了两个基本表或与视图中相同的字段名,要在字段名前加上表名限定,即使用“<表名>.<字段名>”表示。

消除取值重复的行

在上图结果中,我们看到一个学生有几门功课的成绩,如果我们仅仅想看到某个学生是否参加考试,只需要查看学号信息,就可以使用消除重复行的功能。

【例】查询“成绩”表中的学号信息。

USE Students;

SELECT DISTINCT 学号FROM 成绩;

GO

限制返回行数

如果一个表中有大量的数据,而用户仅仅需要前面部分数据,这时可以通过top n关键字查询起那面n条记录,或使用n percent查询前面n%条记录。

【例】查询系部表前4条记录

USE Students;

SELECT TOP 4 * FROM 系部;

 GO

在SELECT语法中,只要SELECT子句需要查询列,就必须使用FROM子句指定将要查询的单个或多个表,指定数据来源。

SELECT语句要查询的数据源还可以是视图,视图相当于临时的表

FROM子句语法:

       FROM  {表名|视图名} [……n]

注意:

  1、 当有多个数据源(表或视图),使用“ , ”分隔

  2、 数据源可以使用别名,即数据源名 AS 别名

如果需要获得满足一定条件的特定记录时,可以通过where子句设定条件值,限制返回结果。Where子句语法格式如下:

Where  条件

其中条件的设置比较灵活,可以使用的条件包括比较运算、逻辑运算、范围、模糊匹配以及未知值。下表是条件表达式类型。

sql server怎么查询表数据 sql server查询语句_数据库

关系运算

【例】查询成绩表中学号为2012180264的学生的成绩。

        

sql server怎么查询表数据 sql server查询语句_sql_02

执行结果如下:

sql server怎么查询表数据 sql server查询语句_sql_03

注意:引用数值类型是CHAR、VARCHAR、TEXT、DATATIME、SMALLDATATIME列的值时,需要使用单引号括住。因为他们是字符(字符串)

【例】在学生表中查询姓名为‘朱德豪’的学生。

use Student
SELECT * FROM 学生 WHERE 姓名 = "朱德豪"

执行结果如下:

sql server怎么查询表数据 sql server查询语句_mysql_04

使用逻辑表达式

多重条件查询时,可以使用逻辑运算符AND、OR、NOT连接多个查询条件

【例】在成绩表中查询期末成绩和平时成绩都大于80的学生。

        

sql server怎么查询表数据 sql server查询语句_sql server怎么查询表数据_05

执行结果如下。

sql server怎么查询表数据 sql server查询语句_sqlserver_06

字符串比较(模糊匹配)

在进行数据查询时,有时候需要使用模糊查询,也就是查找数据库中与用户输入关键字相近或部分匹配的记录。语法格式是:

表达式 [NOT]LIKE <模糊字符串>

其中<模糊字符串>可以包含表所示的通配符                             

sql server怎么查询表数据 sql server查询语句_sqlserver_07

【例】在课程表中查询以基础结尾的课程名称。

        

sql server怎么查询表数据 sql server查询语句_数据库_08

执行结果如下:

sql server怎么查询表数据 sql server查询语句_数据库_09

搜索范围[NOT]BETWEEN …….AND

使用关键字[NOT]BETWEEN AND表示查询结果条件介于两个值之间。

【例】查询成绩表中期末成绩在90与100 之间的学生。

        

sql server怎么查询表数据 sql server查询语句_sql_10

执行代码结果如下。

sql server怎么查询表数据 sql server查询语句_sql_11

使用[NOT]IN关键字

IN的引入是为了更方便的限制检索数据的检索范围,通BETWEEN关键字类似。使用IN 可以通过跟简洁的语句实现复杂的查询。IN关键字语法如下:

    表达式 [NOT] IN(值1、值2、……..值n),表示表达式的值在(或不在)列出的值范围内。

【例】在成绩表中查询期末成绩在60、70、80、90、100取值的学生。

sql server怎么查询表数据 sql server查询语句_sqlserver_12

sql server怎么查询表数据 sql server查询语句_数据库_13

聚合函数

  SQL Serer2016提供了许多聚合函数运算,运算的结果可以作为新列出现在结果集中。聚合函数可以增强数据检索功能。

  在聚合运算的表达式中,可以包括列名、常量以及算数运算符连接的函数。主要的函数有如表所示:                       

函数名

 

函数功能

 

 

  SUM (DISTINCT | ALL) <列名> 

 

 

返回选取结果集所有值的和

 

 

   MAX(DISTINCT | ALL) <列名>  

 

 

返回选取结果集中所有值的最大值

 

 

   MIN(DISTINCT | ALL) <列名>

 

 

返回选取结果集中所有值的最小值

 

 

   AVG(DISTINCT | ALL) <列名> 

 

 

返回选取结果集中所有值的平均值

 

 

   COUNT(DISTINCT | ALL| *)

 

 

 返回选取结果集中行的数目 ,*代表计算所有行的数量,空行也需要计算。

 

其中:DISTINCT表示在计算时不要重复计算,默认是计算所有的(ALL)值。

【例】查询系部的总数。

USE Students;

SELECT count(*) AS 系部总数 FROM 系部;

GO

sql server怎么查询表数据 sql server查询语句_sqlserver_14

【例】查询成绩表中期末成绩的最高分和最低分。

USE Students;

SELECT MAX(期末成绩) AS 最高,MIN(期末成绩) AS 最低 FROM 成绩;

GO

sql server怎么查询表数据 sql server查询语句_sql server怎么查询表数据_15

GROUP BY子句  

GROUP BY 子句用来对查询的结果进行分组,在使用聚合函数查询的时候,结果集是所有行数据的计算结果,如果需要对某一列或多个列的值进行分组,每一组生成一条结果集记录,需要使用GROUP BY子句。

其语法格式如下:

GROUP BY [ALL]列名列表

 [WITH{CUBE  | ROLLUP}]

[HAVING 分组后的筛选条件表达式]

说明:

  • “GROUP BY 列名”按指定的字段进行分组,字段值相同的记录放在一组,每组经汇总后只生产一条记录;
  • HAVING的筛选是对经过分组后的结果集进行筛选,而不是对原始表筛选
  • SELECT后的字段列表必须是聚合函数或GROUP BY子句中的列名。
  • WITH CUBE/ROLLUP表示除了GROUP BY分组的行以外,还包含汇总行。在查询结果内返回每个组和组合的汇总行。

【例】统计学生表中每个班级的学生人数。

USE Students;

SELECT 班级代码,count(*) AS 人数 FROM 学生 GROUP BY 班级代码;

GO

sql server怎么查询表数据 sql server查询语句_sqlserver_16

【例】查询成绩表中期末成绩大于70的学生人数超过50人的课程。

USE Students;

SELECT 课程号,COUNT(*) AS 人数 FROM 成绩  WHERE 期末成绩>=70 GROUP BY 课程号 HAVING COUNT(*)>=50 ;

GO

sql server怎么查询表数据 sql server查询语句_数据库_17

ORDER BY 字句

数据查询过程中,有时需要把查询结果按照一定的顺序排列。使用ORDER BY 子句能够使查询结果的某些列按照一定的方式进行排序(升序或降序)输出。其子句的语法格式是:

ORDER BY 列名称表 [ASC |DESC]

其中:

  1)、列名称表指定需要排序的列,可以是一列,也可以是多列。排序顺序是按照第一列开始排序,如果该列有重复值得时候,按照第二列的顺序排列,一次类推。

  2)、ASC: 指定查询结果按照升序方式排列。如果没有指定排序方式,默认就是升序。

  3)、DESC:排序结果按照降序方式排列。

【例】查询成绩表中的期末成绩,按照降序排列结果。

    

sql server怎么查询表数据 sql server查询语句_mysql_18

执行结果如下。

sql server怎么查询表数据 sql server查询语句_sqlserver_19

注意:在上面排序语句中第一排序是学号,默认是升序,第二排序是期末层级,排序顺序是降序。

INTO子句保存查询

在实际应用中,需要将查询的结果保存到一个新表中。新表的列由SELECT子句中指定的列构成。通过INTO子句实现新表的生成。INTO子句的语法格式如下:

  INTO 新表名

【例】把学生表中把班级为rj1201的学生选择出来,生成rj1201表。

        

sql server怎么查询表数据 sql server查询语句_sql server怎么查询表数据_20

执行完代码后,在结果栏中会出现受影响的行数信息,新表rj1201随之产生,使用SELECT语句可以查询rj1201新表的内容。

sql server怎么查询表数据 sql server查询语句_sql server怎么查询表数据_21

执行select语句查询新表内容

select * from rj1201;

sql server怎么查询表数据 sql server查询语句_mysql_22