9 数据检索(一)简单查询.ppt
文本预览下载声明
数据检索(一)简单查询;Application Logic;怎样查询呢?;数据查询;编写查询语句之前…;SQL Sever管理平台—查询;SQL Sever管理平台—查询;1 简单查询 ;1.1 SELECT 语句的基本语法格式;1.1 SELECT 语句的基本语法格式;检索表中数据可以使用SELECT语句。在SELECT语句中,有3个基本的组成部分:SELECT子句、FROM子句和WHERE子句。SELECT子句用于指定将要检索的列名称,FROM子句指定将要检索的对象,WHERE子句则用于指定数据应该满足的条件。
在一般的检索操作中,SELECT子句和FROM子句是必不可少的。只有当SELECT子句中仅包括常量、变量或算术表达式(没有列名)时,FROM子句才可以省略。WHERE子句是可选的。如果没有使用WHERE子句,表示检索所有的数据。
;最基本的检索语句(网格显示形式);1.2 选择表中的若干列 ;2. 输出表中部分列
例2:查询“课程”表中的课程号和课程名称。
代码如下:
USE student
GO
SELECT 课程号,课程名称
FROM 课程
GO;选择指定的数据列是指可以在SELECT子句中指定将要检索的列名称。
选择指定的列名称要注意以下几点:第一,这些列名称应该与表中定义的列名称一致,否则就可能出错或者得到意想不到的结果;第二,列名称之间的顺序既可以与表中定义的列顺序相同,也可以不相同;第三,SELECT语句的检索结果只是影响数据的显示,对表中存储的数据没有任何影响。
;1.2 选择表中的若干列 ;3. 为结果集内的列指定别名
例3:查询学生表中全体学生的姓名及年龄。
代码如下:
USE STUDENT
GO
SELECT 姓名,YEAR(GETDATE())-YEAR(出生日期) AS 年龄
FROM 学生
GO ;改变列标题;改变列标题;1.3 选择表中的若干记录 ;使用ALL和DISTINCT关键字;使用DISTINCT关键字;使用ALL关键字;1.3 选择表中的若干记录 ;3. 查询满足条件的元组
常用的查询条件 :;查询满足条件的元组;在WHERE子句中,简单搜索条件是指使用比较运算符、范围、列表、合并以及取反等运算方式形成的搜索条件。
;查询满足条件的元组;例6 :查询年龄小于或等于35岁教师的信息。
代码如下:
USE student
GO
SELECT *
FROM 教师
WHERE YEAR(GETDATE())-YEAR(出生日期)=35
GO;例7:查询出生日期在1971年至1980年之间的教师编号、姓名和出生日期。
代码如下:
USE student
GO
SELECT 教师编号,姓名,出生日期
FROM 教师
WHERE 出生日期BETWEEN 1971-01-01 AND 1980-12-31
GO;例8:查询计算机系、经济管理系的班级名称与班级编号。
代码如下:
USE student
GO
SELECT 班级代码,班级名称
FROM 班级
WHERE 系部代码 IN(01,02)
GO;模糊搜索条件;LIKE关键字;使用LIKE子句;例9:查询“学生”表中姓“刘”的同学的信息。
代码如下:
USE student
GO
SELECT *
FROM 学生
WHERE 姓名 LIKE 刘%
GO;例10:有一门课程的名称是“Delphi_6.0”,那么查询它的课程号和课程名称的代码如下:
USE student
GO
INSERT INTO 课程 (课程号, 课程名称, 备注)
VALUES (0005, Delphi_6.0, 程序设计)
GO
SELECT 课程号,课程名称
FROM 课程
WHERE 课程名称 LIKE Delphi/_6.0 ESCAPE/
GO;例11:查询“班级”表中备注字段为空的班级信息
代码如下:
SELECT *
FROM 班级
WHERE 备注 IS NULL
GO
这里的IS 运算符不能用“=”代替。
;复合搜索条件;使用复合搜索条件;例12:查询“教师”表中出生日期在1971年至1980年之间的女教师信息。
代码如下:
SELECT *
FROM 教师
WHERE 出生日期 BETWEEN 1971-01-01 AND 1980-12-31 AND 性别=女
GO;在使用SELECT语句时,排序是一种常见的操作。排序是指按照指定的列或其他表达式对结果集进行排列顺序的方式。
SELECT语句中的ORDER BY子句负责完成排序操作。在排序时,可以按照升序排列,也可以按照降序排列。关键字ASC表示升序,DESC表示降序,默认情况下是升序。
;没有使用ORDER BY子句的检索操作;使用一个列进行排序;使用3个列进行
显示全部