• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > SqlServer 2005 T-SQL Query 学习笔记(1)

SqlServer 2005 T-SQL Query 学习笔记(1)

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了SqlServer,T-SQL等相关知识,希望本文的分享对您有所帮助

SqlServer 2005 T-SQL Query 学习笔记(1)

Select字句在逻辑上是SQL语句最后进行处理的最后一步,所以,以下查询会发生错误:

OrderDateOrderYearCustomerIDNumCusts
dboOrders
OrderYear

因为group by是在Select之前进行的,那个时候orderYear这个列并没有形成。

如果要查询成功,可以像下面进行修改:

OrderYearCustomerIDNumCusts
OrderDateOrderYearCustomerID
   dboOrdersD
OrderYear

还有一种很特殊的写法:

OrderYearCustomerIDNumCusts
OrderDateCustomerID
   dboOrdersDOrderYearCustomerIDOrderYear

在作者眼里,他是非常喜欢这种写法的,因为更清晰,更明确,更便于维护。

在查询中使用参数定向产生一批结果,这个技巧没有什么好说的。

嵌套查询,在处理逻辑上是从里向外进行执行的。

多重引用,有可能你的SQL语句包含了多次从一个表进行查询后进行连接组合。比如你要比较每年的顾客数同先前年的顾客数的变化,所以你的查询就必须JOIN了2个相同的表的实例,这也是不可避免的。

Common Table Expressions (CTE)

CTE是在SQL2005新加入的一种表的表示类型。

它的定义如下:

WITH cte_name

AS

(

cte_query

)

outer_query_refferring to_cte_name;

注意:因为在标准的T-SQL语言中已经包含了WITH关键字,所以为了区分,CTE在语句的结尾加上了“;”作为停止符。

CTE实例一(结果集别名)

C OrderDateOrderYearCustomerID
 dboOrders
OrderYearCustomerIDNumCusts
C
OrderYear

当然,作者本人有更推荐的写法:

COrderYearCustomerIDOrderDateCustomerID
 dboOrders
OrderYearCustomerIDNumCusts
C
OrderYear

CTE实例二(多重CTEs)

C1 OrderDateOrderYearCustomerID
 dboOrders
C2 OrderYearCustomerIDNumCusts
 C1
 OrderYear
OrderYearNumCusts
C2
NumCusts 70

CTE实例三(多重引用)

YearlyCount OrderDateOrderYearCustomerIDNumCusts
 dboOrders
 OrderDateCurOrderYearCurNumCusts CurNumCustsPrvNumCusts PrvNumCustsCurNumCusts PrvNumCusts Growth
YearlyCount Cur
 YearlyCount Prv
  CurOrderYear PrvOrderYear 1

CTE实例四(修改数据)

1.把从customer表查询出来的结果,动态的组装进新表CustomersDups里:

dboCustomersDupsGO

CrossCustomers 1 cC1dboCustomers C1dboCustomers C2
cKeyColCustomerIDCompanyNameContactNameContactTitleCityRegionPostalCodeCountryPhoneFax
dboCustomersDups
CrossCustomers

2.使用CTE移除数据,只保留CustomerDups表里同一CustomerID里KeyCol为最大的记录。

JustDups dboCustomersDups C1
 KeyCol KeyColdboCustomersDups C2
   C2CustomerID C1CustomerIDJustDups

CTE实例五(对象容器)

即提供了封装的能力,有利于组件化的编程。作者额外的提醒,CTE无法直接内嵌,但是可以通过把CTE封装进一个对象容器里并从一个外部的CTE里对这容器的数据进行查询而实现内嵌。

作者也说明了,使用CTEs在VIEW和UDFs里是没有什么价值的。

有个例子,如下:

dboVYearCnt
YearCnt OrderDateOrderYearCustomerIDNumCusts
 dboOrders
 OrderDateYearCnt

CTE实例六(CTEs的递归)

作者给了一个例子,来讲述这个在SQL2005的新内容,CTEs的递归。

根据employeeId,返回此员工的信息,并包含所有下级员工的信息。(等级关系基于empolyeeId和reportsTo的属性)所返回的结果包含下列字段,employeeId,reportsTo,FirstName,LastName。

作者在这里,给予了一个最佳的索引方式:

idx_mgr_emp_ifname_ilname
 dboEmployeesReportsToEmployeeIDFirstNameLastName

作者的解释: 这个索引将通过一个单独的查询(局部扫描)来取得每个经理的直接下级。Include(FristName,LastName)加在这里,即是覆盖列。

小知识:什么Include索引?

Include索引是SQL2005的新功能。Include索引的列并不影响索引行的物理存储顺序,他们作为一个挂件‘挂在'索引行上。挂这些‘挂件'的目的在于,只需要扫描一把索引就获得了这些附加数据。

回到作者的例子上,下面是递归的代码:

EmpsCTE EmployeeIDReportsToFirstNameLastName
 dboEmployees
 EmployeeID 5
 EMPEmployeeIDEMPReportsToEMPFirstNameEMPLastName
 EmpsCTE MGR
  dboEmployees EMP
   EMPReportsTo MGREmployeeID
EmpsCTE

理解:一个递归的CTE包含了至少2个查询,第一个查询在CTE的身体里类似于一格锚点。这个锚点仅仅返回一个有效的表,并作为递归的一个锚。从上的例子看出来,锚点仅仅返回了一个employeeID = 5 的一行。然后的第2个查询是作为递归成员。当查询到下属成员的结果为空时,此递归结束。

如果你担心递归会造成永久循环,你可以使用下面的表达:

WITH cte_name AS (cte_body) outer_query OPTION (MAXRECURSION n);

默认的n为100,当n=0时,无限制。

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 如何获取SqlServer2005表结构(字段,主键,外键,递增,描述)
  • 如何在SQL Server中实现 Limit m,n 的功能
  • 深入Mysql,SqlServer,Oracle主键自动增长的设置详解
  • 小编带你深入解析SQL Server索引的原理
  • sqlserver帐号被禁用如何处理
  • sqlserver查询锁住sql以及解锁的方法
  • MS SQLServer 批量附加数据库的方法
  • SqlServer 2008 创建测试数据的方法
  • 讲解有关sqlserver分页查询处理方法
  • MYSQL同步Sqlserver数据库数据

相关文章

  • 2018-12-05数据结构简明备忘录 线性表
  • 2018-12-05关于mysql中coalesce()使用的技巧总结(必看)
  • 2018-12-05mysql中怎么样指定某行或者某列的排序实现方法分析(图)
  • 2018-12-05Sql Server 2000 行转列的实现(横排)
  • 2017-05-11浅谈MySQL中优化sql语句查询常用的30种方法
  • 2018-12-05MySQL查询某个记录行号
  • 2018-12-05mysql数据库分库分表技术难点解决策略
  • 2018-12-05mssql2005数据库镜像搭建教程
  • 2018-12-05关于SSE的10篇文章推荐
  • 2018-12-05Oracle行级锁的特殊用法简析

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • 深入理解MySQL进阶漂流记(五)
    • Mysql学习总结(16)Mysql之数据库设计规范_MySQL
    • mongodb 3.4下远程连接认证失败应该怎么办?
    • Mysql中日期和时间函数应用不用求人
    • 在.Net中操作SQLite数据库的详细优点有哪些?
    • C3P0连接池+MySQL的配置及wait_timeout问题的解决方法_MySQL
    • mysql 游标使用模版
    • mssql2005数据库镜像搭建教程
    • 创建一个实现Disqus评论模版的MySQL模型
    • mysql 查询数据库中的存储过程与函数的语句

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有