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交流群 (群号:54525238) Access源码网店
常见问答:
技术分类:
源码示例
- 【源码QQ群号19834647...(12.17)
- Access对子窗体数据进行批...(10.30)
- 最精简的组合框行来源数据快速输...(10.25)
- Access仿平台的多值选择器...(10.24)
- 【Access日期区间段查询】...(10.22)
- 【Access源码示例】VBA...(10.12)
- Access累乘示例,Acce...(10.09)
- 数值8.88,把整数8去掉,转...(10.08)
- 【Access自定义函数】一个...(09.30)
- 【Access选项卡示例】Ac...(09.09)
学习心得
最新文章
- Access快速开发平台企业版--...(11.18)
- 不会用多表联合查询,多表查询没结果...(11.16)
- 【案例分享】主键字段值含有不间断空...(11.16)
- Access快速开发平台--后台D...(11.14)
- 微软Access邀测新Monaco...(11.12)
- Access列表框左右互选、列表框...(11.11)
- 高效率在导入数据前删除记录(11.10)
- Access报价单转订单示例代码(11.08)
- Access系统自带的日期选择器不...(11.08)
- 分享一下Access工程中的acw...(11.07)