Access开发培训
网站公告
·Access专家课堂QQ群号:151711184    ·Access快速开发平台下载地址及教程    ·欢迎加入Access专家课堂微信群!    ·如何快速搜索本站文章|示例|资料    
您的位置: 首页 > 技术文章 > Access数据库-教程

SQL必知必会(10) 使用WHERE子句

时 间:2009-07-31 08:29:22
作 者:(美)Ben Forta 著   ID:1445  城市:上海
摘 要:使用WHERE子句  
正 文:

使用Where子句

数据库表一般包含大量的数据,很少需要检索表中所有行。通常只会根据特定操作或报告的需要提取表数据的子集。只检索所需数据需要指定搜索条件(search criteria),搜索条件也称为过滤条件(filter condition)。

在Select语句中,数据根据Where子句中指定的搜索条件进行过滤。Where子句在表名(FROM子句)之后给出,如下所示:

这条语句从products表中检索两个列,但不返回所有行,只返回prod_price值为3.49的行,如下所示:

这个例子采用了简单的相等测试:它检查一个列是否具有指定的值,据此进行过滤。但是SQL允许做的事情不仅仅是相等测试。

PostgreSQL例外  PostgreSQL对传递给SQL语句的值具有严格的管理条件,特别是对于十进制数的列所用的数更是如此。因此,上面的例子对于PostgreSQL可能不起作用。为使这个例子在PostgreSQL中正常工作,可能需要在Where子句中包含类型,明确告诉PostgreSQL,3.49是一个合法的数。为此目的,应该将=3.49替换为= decimal '3.49'。

SQL过滤与应用过滤  数据也可以在应用层过滤。为此目的,SQL的Select语句为客户机应用检索出超过实际所需的数据,然后客户机代码对返回数据进行循环,以提取出需要的行。

通常,这种实现并不令人满意。因此,对数据库进行了优化,以便快速有效地对数据进行过滤。让客户机应用(或开发语言)处理数据库的工作将会极大地影响应用的性能,并且使所创建的应用完全不具备可伸缩性。此外,如果在客户机上过滤数据,服务器不得不通过网络发送多余的数据,这将导致网络带宽的浪费。

Where子句的位置  在同时使用ORDER BY和Where子句时,应该让ORDER BY位于Where之后,否则将会产生错误(关于ORDER BY的使用,请参阅第3章)。

上一章  下一章



Access软件网QQ交流群 (群号:483923997)       Access源码网店

常见问答:

技术分类:

相关资源:

专栏作家

关于我们 | 服务条款 | 在线投稿 | 友情链接 | 网站统计 | 网站帮助