首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > C++ Builder >

SQL中的with语句?解决方法

2012-02-06 
SQL中的with语句?在备份和还原数据库时,看见有列子在SQL语句里出现with init和with replace小弟想多学习下

SQL中的with语句?
在备份和还原数据库时,看见有列子在SQL语句里出现with init和with replace
小弟想多学习下,这些是什么意思?
with ____这样列子还有其它什么?讲解下,谢谢

[解决办法]
就如同命名集和导出成员一样,WITH关键字也被用来建立查询层级的快取,对该单一查询可永久使用。
公用表表达式(CTE)
CTE的语法:
[ WITH <common_table_expression> [ , n ] ]
<common_table_expression>::=
expression_name [ ( column_name [ , n ] ) ]
AS
( CTE_query_definition )
在使用CTE时应注意如下几点:
1. CTE后面必须直接跟使用CTE的SQL语句(如select、insert、update等),否则,CTE将失效。如下面的SQL语句将无法正常使用CTE:
2. CTE后面也可以跟其他的CTE,但只能使用一个with,多个CTE中间用逗号(,)分隔
3. 如果CTE的表达式名称与某个数据表或视图重名,则紧跟在该CTE后面的SQL语句使用的仍然是CTE
4. CTE 可以引用自身,也可以引用在同一 WITH 子句中预先定义的 CTE。不允许前向引用。
5. 不能在 CTE_query_definition 中使用以下子句:
(1)COMPUTE 或 COMPUTE BY
(2)ORDER BY(除非指定了 TOP 子句)
(3)INTO 
(4)带有查询提示的 OPTION 子句
(5)FOR XML
(6)FOR BROWSE
6. 如果将 CTE 用在属于批处理的一部分的语句中,那么在它之前的语句必须以分号结尾

热点排行