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

MSSQL
SQL Server教程:备份和恢复措施
合理建立索引-提高SQL Server的性能之法
SQL Server查询过程中 实际消耗了多大内存?
教程:SQL Server 2008 数据挖掘的概念
在SQL Server中生成脚本的方法
如何提高SQL Server复制的向后兼容性
为SQL Server 2008添加报表服务的虚拟目录
在SQL Server中创建全局临时表
SQL Server触发器的使用方法
如何通过调整Windows参数提高数据库服务器性能
详解SQL Server 2005 FOR XML嵌套查询的使用
初识Sybase数据库
浅谈SQL Server Compact的DLL文件
丢失的数据忘记备份怎么办?
SQLServer数据库中如何保持数据一致性
教你解决SQLServer与服务器连接时出错
SQLServer中游标是如何处理数据的?
SQL Sever性能怎样全方位诊断?
SQL Server教程:详细学习游标
详解SQLServer 存储过程

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 108 ::
收藏到网摘: 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: