SQL必知必会(10) 使用WHERE子句 -小周
Access软件网QQ交流学习群(群号码198465573),欢迎您的加入!
首页 >技术文章> Access数据库-教程


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

发表时间:2009/7/31 8:29:22 评论(0) 浏览(6606)  评论 | 加入收藏 | 复制
   
摘 要:使用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群(群号:198465573)
 
 相关文章
SQL必知必会(6)排序数据   【(美)Ben Forta   2009/7/27】
SQL必知必会(7)按多个列排序   【(美)Ben Forta 著  2009/7/28】
SQL必知必会(8)按列位置排序   【(美)Ben Forta 著  2009/7/29】
SQL必知必会(9)指定排序方向  【(美)Ben Forta 著  2009/7/30】
SQL必知必会(11)WHERE子句操作符   【(美)Ben Forta 著  2009/8/1】
常见问答
技术分类
相关资源
文章搜索
关于作者

小周

文章分类

文章存档

友情链接