SQL必知必会(10) 使用WHERE子句
时 间:2009-07-31 08:29:22
作 者:(美)Ben Forta 著 ID:1445 城市:上海
摘 要:使用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源码网店
常见问答:
技术分类:
源码示例
- 【源码QQ群号19834647...(12.17)
- 【Access窗体导出PDF】...(04.08)
- 【Access窗体导出PDF】...(04.07)
- Access两种方式实现即时更...(03.01)
- Access隐藏与显示lacc...(01.12)
- 【Access高效办公】将每个...(12.23)
- Access21点游戏源代码(12.13)
- 【Access窗体导出Exce...(11.15)
- 【Access开发】Acces...(11.14)
- 通过Access宏录入数据到选...(11.10)
学习心得
最新文章
- Access VBA语句If Me...(04.24)
- 【Access修改记录示例】编辑选...(04.22)
- 【Access表名称命名建议】将A...(04.20)
- Access学习笔记--用Acce...(04.19)
- 【Access重复项查询示例】将A...(04.17)
- Access快速开发平台企业版--...(04.16)
- 【Access模块示例】通过模块代...(04.15)
- Access查询里面分组合计功能添...(04.13)
- 【Access删除查询】删除数字最...(04.12)
- 显示文件夹中所有文件的修改时间(04.11)