当前位置: 首页 > 图文教程 > 数据库 > MSSQL > SQL Server数据库技术(59)

MSSQL
如何在 SQL SERVER 中快速有条件删除海量数据
Transact_SQL 小手册
一个过滤重复数据的 SQL 语句
MS-SQL Server 2005 其中三个版本的比较
SQL Server 的 SQL 语句导入导出大全
一些 T-SQL 技巧
显示 Sql Server 中所有表中的信息
MS-SQL Server 中单引号的两种处理方法
sql数据库不能直接用instr函数
MDF文件在SQL Server中的恢复技术
SQL Server 中调整自增字段的当前初始值
如何创建SQL Server 2000故障转移群集
SQL Server连接失败错误及解决
最长用最基本的MSSQL数据库备份与还原
清除SQLServer日志的两种方法
如何强制删除或恢复SQLServer正在使用的数据库
如何恢复数据库备份到一个已存在的正在使用的数据库上
设定sql server定期自动备份数据库
xp_cmdshell开启与关闭
更改SQL Server更改当前数据库的所有者:sp_changedbowner

MSSQL 中的 SQL Server数据库技术(59)


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 26 ::
收藏到网摘: n/a

从本节开始,我们将用大量的实例来讲述SELECT 语句的应用。首先从最简单也是最常用的单表查询开始。
10.2.1 选择列
(1) 用SELECT 子句来指定查询所需的列,多个列之间用逗号分开


(2) 可以使用符号“*”来选取表的全部列


(3) 在查询结果中添加列

10.2.2 选择行
(1) 使用WHERE 子句
用户在查询数据库时,往往并不需要了解全部信息,而只需要其中一部分满足某些条件的信息。在这种情况下就需要在SELECT 语句中加入条件,以选择数据行,这时就用到WHERE 子句。WHERE 子句中的条件是由表达式以及逻辑联结词AND、 OR、NOT 等组成。

例10-4: 查询工资介于2000 元和3000 元之间的员工姓名。
use pangu
select e_name
from employee
where e_wage between 2000 and 3000
运行结果如下:
e_name
--------------------
王二
伍将
(2 row(s) affected)

(2) 使用DICTINCT 关键字
用户在对数据库进行查询时,会出现重复结果,这时就需要使用DISTINCT 关键字消除重复部分。
例10-5: 列出工资大于7000 的员工所属的部门编号。
use pangu
select distinct dept_id
from employee
where e_wage > 7000
运行结果如下:
dept_id
-------
1001
1005
(2 row(s) affected

(3) 使用IN 关键字
在使用WHERE 子句进行查询时,若条件表达式中出现若干条件相同的情况,就会使表达式显得冗长,不便于用户使用,这时可用IN 关键字来简化。
例10-6: 查询在编号为‘1001’ 和‘1002’ 的部门中工作的员工姓名。
use pangu
select e_name
from employee
where dept_id in (’1001’,’1002’)
运行结果如下:
e_name
--------------------
张三
李四
......
(4) 使用通配符
在WHERE 子句中可以使用谓词LIKE 来进行字符串的匹配检查,其中将大量使用我们在Transact-SQL 语言基础中介绍到的通配符。


如果用户要查找的数据中本身就包含了通配符,如“SQL_Mail”, 就需要使用逃逸字符来区分通配符与实际存在的字符。其格式如下;
LIKE ‘字符匹配串’ ESCAPE ‘逃逸字’



10.2.3 对查询结果排序
(1) 使用ORDER 子句
当用户要对查询结果进行排序时就需要在SELECT 语句中加入ORDER BY 子句。在ORDER BY 子句中可以使用一个或多个排序要求,其优先级次序为从左到右。
例10-9: 查询工作级别为‘2’ 的员工姓名,查询结果按工资排序。


(2) 选取前几行数据
在SELECT 语句中使用TOP n 或TOP n PERCENT, 来选取查询结果的前n 行或前百分之n 的数据。此语句经常和ORDER 子句一起使用。
例10-11: 查询工资最高的三名员工的姓名和工资。
use pangu
select top 3 e_name, e_wage
from employee
order by e_wage desc
运行结果如下:
e_name e_wage
-------------------- ---------------------
张三 8000.0000
大师傅 7500.0000
张龙 7000.0000
(3 row(s) affected)

10.2.4 查询结果分组
(1) 使用GROUP 子句
当用户要对查询结果进行分组时,就需要在SELECT 语句中加入GROUP BY 子句。
例10-12: