使用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章)。
|
上一章 下一章