Sql学习第二天——SQL DML与CTE概述

 更新时间:2013年03月22日 11:24:56   作者:  
关于DML即数据操纵语言;关于CTE即公用表表达式,接下来为大家介绍下CTE使用的地方以及优点同时提供一个简单的CTE例题,感兴趣的各位可以参考下哈
DML (Data Manipulation Language) 与 CTE (Common Table Expression)
今天看书时遇到的两个缩写,不知道其含义,于是就百度了一下,特地在此记录下来,以便于下次复习使用。

关于DML (Data Manipulation Language):
数据操纵语言,用户能够查询数据库以及操作已有数据库中的数据的计算机语言。具体是指是UPDATE更新、INSERT插入、DELETE删除。

关于CTE (Common Table Expression):
CTE(Common Table Expression) ,即公用表表达式,可以认为是在单个 SELECT、INSERT、UPDATE、DELETE 或 CREATE ⅥEW 语句的执行范围内定义的临时结果集。CTE与派生表类似,具体表现在不存储为对象,并且只在查询期间有效。与派生表的不同之处在于,CTE 可自引用,还可在同一查询中引用多次。

CTE可用于:
1.创建递归查询(我个人认为CTE最好用的地方)。
2.在同一语句中多次引用生成的表。

CTE优点:
1.使用 CTE 可以获得提高可读性和轻松维护复杂查询的优点。
2.查询可以分为单独块、简单块、逻辑生成块。之后,这些简单块可用于生成更复杂的临时 CTE,直到生成最终结果集。
CTE可使用的范围:
可以在用户定义的例程(如函数、存储过程、触发器或视图)中定义 CTE。

下面看一个简单的CTE例题:
把test表中salary最大的id记录保存在test_CTE中,再调用

代码如下:
复制代码 代码如下:

with test_CTE(id,salary)
as 
(
select id,max(salary)
from test
group by id 
)
select * from test_cte

相关文章

  • SQLServer审计功能配置详细图文教程

    SQLServer审计功能配置详细图文教程

    这篇文章主要给大家介绍了关于SQLServer审计功能配置的相关资料,SQL Server 的审计功能可以捕获数据库的活动和事件,包括登录、DDL 和 DML 操作、失败的登录尝试、权限更改等,需要的朋友可以参考下
    2024-01-01
  • SQLserver存储过程写法与设置定时执行存储过程方法详解

    SQLserver存储过程写法与设置定时执行存储过程方法详解

    一直都很想了解如何写存储过程,对于不熟悉的东西,总是觉得很神秘,下面这篇文章主要给大家介绍了关于SQLserver存储过程写法与设置定时执行存储过程方法的相关资料,需要的朋友可以参考下
    2023-03-03
  • SQL Server数据表压缩

    SQL Server数据表压缩

    本文详细讲解了SQL Server数据表压缩,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-05-05
  • SQL Server的触发器详解

    SQL Server的触发器详解

    本文详细讲解了SQL Server的触发器,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • Sql注入工具_动力节点Java学院整理

    Sql注入工具_动力节点Java学院整理

    这篇文章主要为大家详细介绍了Sql注入工具的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • sqlserver如何生成连续数值,字母,字符

    sqlserver如何生成连续数值,字母,字符

    这篇文章主要介绍了sqlserver如何生成连续数值,字母,字符问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • sql中case语句的用法浅谈

    sql中case语句的用法浅谈

    今天看资料的时候,看到了sql中使用case的一些使用方法,做个记录
    2013-05-05
  • 清除SQLServer日志的两种方法

    清除SQLServer日志的两种方法

    清除SQLServer日志的两种方法...
    2007-01-01
  • SQL语句查询是否为空 =null及null

    SQL语句查询是否为空 =null及null

    SQL语句查询是否为空 =null及null实现代码。
    2009-06-06
  • SQL Server作业报错特殊案例分析

    SQL Server作业报错特殊案例分析

    这篇文章主要给大家介绍了关于SQL Server作业报错特殊案例的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者使用SQL Server具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-03-03

最新评论