下面是with使用的一个实例:
--使用with定义基础表 WITH RES_USER AS (SELECT VU.USER_ID,VU.NAME FROM USER_TABLE VU),RES_ORG AS(SELECT VO.ORG_ID,VO.NAME FROM ORG_TABLE VO) SELECT T.* , (SELECT NAME FROM RES_USER U WHERE U.USER_ID=T.useId) uName, (SELECT NAME FROM RES_ORG O WHERE O.ORG_ID=T.orgId) oName FROM TABLE_NAME_2 T where T.ID=''
with用法在作为基础表的时候很方便从一个表中选取不同的结果,将公用的结果放在内存中,整体来说还是降低内存的消耗。
with通常与AS连用,也叫做子查询部分。用法如下:
1.用来定义一个sql片段,该片段会被整改sql语句所用到:
WITH RES_USER AS (SELECT VU.USER_ID,VU.NAME FROM USER_TABLE VU)
2.可以使sql语句的可读性更高
3.也有可能在UNION ALL的不同部分,作为提供数据的部分。特别对于UNION ALL比较有用。因为UNION ALL的每个部分可能相同,但是如果
每个部分都执行一次则成本太高,所以使用WITH AS 短语,则只要执行一次
相关推荐
### Oracle数据库中的START WITH 和 CONNECT BY 用法详解 在Oracle数据库中,处理层次结构数据时,`START WITH` 和 `CONNECT BY` 是非常有用的两个关键字。这些关键字可以帮助我们在查询时构建出树形或者层级结构的...
一.WITH AS的含义 WITH AS短语,也叫做子查询部分(subquery factoring),可以让你做很多事情,定义一个SQL片断,该SQL片断会被整个SQL语句所用到。有的时候,是为了让SQL语句的可读性更高些,也有可能是在UNION ...
### SQL语言的高级用法详解 #### 一、利用`TOP n`列出结果集中的前n个记录 在SQL查询中,`TOP n`关键字是一个非常实用的功能,它允许我们从查询结果中提取前n个记录。这在分析数据、展示最热门或最新的项目时特别...
SQL Server Broker(SQL Service Broker,简称SSB)是微软在SQL Server中提供的一种异步消息队列技术,用于实现数据库间的可靠通信和异步处理。它允许数据库应用程序发送和接收消息,提供了高可用性、安全性和可扩展...
以上只是SQL高级用法的一部分,实际应用中还有更多技巧和策略,如性能调优、数据库设计原则以及SQL标准的不断演进。通过深入学习和实践这些知识点,你可以成为一个高效的SQL开发者,无论是在数据分析、报表生成还是...
下面将详细解释CTE的用法以及在给定示例中的应用。 CTE的基本语法结构如下: ```sql WITH CTE_Name (Column1, Column2, ...) AS ( SELECT Column1, Column2, ... FROM SomeTable WHERE SomeCondition ) SELECT...
下面介绍SQL中Truncate的用法 当你不再需要该表时, 用 drop;当你仍要保留该表,但要删除所有记录时, 用 truncate;当你要删除部分记录时(always with a WHERE clause), 用 delete. Truncate是一个能够快速清空...
本书《Beginning T-SQL with Microsoft SQL Server 2005 and 2008》由Paul Turley和Dan Wood合著,是为那些希望学习Transact-SQL(简称T-SQL)语言以及如何在Microsoft SQL Server 2005和2008环境中使用该语言的专业...
SQL Server中的用法为group by colomn with [rollup|cube],首先要弄明白rollup 和cube,就要知道group by的用法,group by 为对列进行分组,只展现分组统计的值,而 rollup 为分层次展现,cube 为展现列中所有层次...
"SQL SERVER BULK INSERT用法" BULK INSERT 是 SQL Server 中的一种 BulkCopy 功能,允许用户快速将大量数据从文本文件或其他数据源导入到数据库表或视图中。下面是 BULK INSERT 的详细用法和参数解释: 基本语法 ...
在数据库管理领域,尤其是SQL语言的应用中,"WITH CHECK OPTION"是一个重要的概念,它主要用于视图的定义中,以限制通过视图进行的数据修改操作。本文将深入探讨WITH CHECK OPTION的用法及其背后的原理,帮助读者更...
### SQL中row_number函数详解与应用 #### 一、row_number函数概述 `row_number()` 是SQL中的一个重要窗口函数,用于为每一行分配一个唯一且连续的整数。这一功能在处理复杂的数据排序和筛选场景时非常有用。下面将...
根据提供的文件信息,我们可以深入探讨Oracle数据库中的几个关键知识点:序列的创建、各种类型的约束以及用户的解锁操作。接下来,我们将详细地对这些知识点进行解析。 ### 一、Oracle中序列的创建 序列在Oracle...
在SQL Server中,`PARTITION BY` 和 `ROW_NUMBER()` 是两种非常重要的分析函数,它们在处理大数据集时尤其有用。本文将详细讲解这两个函数的使用方法及其在实际场景中的应用。 `PARTITION BY` 关键字是分析函数的一...
本文将基于提供的内容,总结SQL Server的主要用法,包括创建数据库、表、默认值、规则、标识列、视图、索引以及存储过程等。 1. **创建数据库**: 使用`CREATE DATABASE`语句可以创建新的数据库,例如`CREATE ...
以下是对标题"SQL Server用法总结"中涉及的一些核心知识点的详细说明: 1. **创建数据库**:使用 `CREATE DATABASE` 语句可以创建新的数据库。例如,`CREATE DATABASE baiyunfei;` 将创建一个名为 "baiyunfei" 的...
《SQL Server 2005 技术内幕:T-SQL查询源码》是一本深入探讨SQL Server 2005中T-SQL查询技术的专业书籍。T-SQL(Transact-SQL)是Microsoft SQL Server数据库管理系统中使用的SQL扩展版本,它在标准SQL的基础上增加...
### SQL Server 2000 内置存储过程用法与说明 #### 一、引言 随着互联网技术的发展和数据库应用的普及,SQL Server 2000 作为一款主流的关系型数据库管理系统(RDBMS),其安全性问题日益受到关注。在实际应用中,...