领先的免费Web技术教程,涵盖HTML到ASP.NET

网站首页 > 知识剖析 正文

初学者最热门和棘手的10个T-SQL问题

nixiaole 2024-12-04 14:30:06 知识剖析 15 ℃

T-SQL有助于在物理或虚拟实例中创建和管理对象,以及插入、检索、修改和删除数据表。

国际标准化组织(ISO)和美国国家标准协会(ANSI)发布的SQL标准定义了一种软件语言,Transact-SQL就是从这个定义发展和扩展而来的。

如果您是T-SQL的粉丝,以下是针对初学者的T-SQL Server面试问题:

SQL、T-SQL和PL/SQL之间有什么区别?

  • SQL是一种对集合进行操作的查询语言,集合是ISO和ANSI的标准。几乎所有的关系数据库管理系统都或多或少地使用了它:SQLServer、Oracle、MySQL、PostgreSQL、DB2、Informix等。
  • T-SQL和PL/SQL是标准SQL的方言
  • PL/SQL是SQL与Oracle公司开发的编程语言的过程特性的结合
  • TSQL是Microsoft在sqlserver中使用的一种专有过程语言,是SQL的一种扩展形式,它向SQL中添加了声明变量、事务控制、错误和异常处理以及行处理

ON子句和WHERE子句有什么区别?

  • where子句适用于整个结果集。
  • on子句只适用于有问题的连接。

是否保证WHERE子句中的表达式将按特定顺序进行计算

  • 如果SQL Server确定表达式的计算结果为TRUE或FALSE,则表达式将短路
  • 您没有查询提示,您可以应用于强制优化器使用您编写的精确表达式,以便表达式在SQL Server构建的计划中显示相同的方式。

空值的目的是什么,它们给语言增加了什么样的复杂性?

  • 在SQL中,NULL是一个标记或占位符,表示缺少的值。
  • 基于SQLPerformance.com网站:“空值为您的SQL代码编写增加了复杂性。您总是希望考虑数据中可能存在的空值,确保使用正确的查询构造,并将相关逻辑添加到解决方案中以正确处理空值。忽略它们肯定会导致代码中出现错误。”

将表与派生表联接时,派生表查询是否可以引用联接中其他表的列,为什么?

  • 派生表是嵌套在FROM子句中的子查询。
  • FROM子句中的子查询必须具有名称。
  • 由于在FROM子句中,子查询的结果集可以类似于SQLServer表使用。
  • 作为联接一部分的派生表不能引用子查询范围之外的对象。
  • 属于APPLY的派生表可以引用子查询范围之外的列。

您能使用WHERE子句中SELECT子句中定义的列别名吗?为什么?

列别名可以在orderby子句中使用,但由于SELECT子句在WHERE、GROUP BY和have子句之后处理,因此不能在WHERE、GROUP BY或have子句中使用。

如何使列别名可用于WHERE、GROUP BY、HAVING、SELECT等子句?

使用CTE或派生表,但这种方法增加了代码的复杂性。

查询中有按子句表示顺序时,查询结果的性质与不存在时的区别是什么?

指定ORDER BY时,结果不再是关系型的,而是标准SQL所称的游标。

当我们针对表发出查询,而不明确表示要以特定的表示顺序返回行时,结果应该是关系的。

组聚合函数和窗口聚合函数之间有什么区别?

  • SQL Server窗口函数基于一组行计算聚合值,并为每个组返回多行。
  • 聚合函数执行一个或多个值的计算,并返回一个值。
  • 聚合函数通常与GROUP BY子句和SELECT语句的HAVICE子句一起使用。

如果您在查询中没有展现orderby子句,是否有任何情况可以保证查询的呈现顺序?

  • 唯一可靠地按特定顺序传递行的是一个显式ORDERBY子句。
  • 但由于以下原因,可以保证特定订单:
  1. RDMBS es具有不同的行为
  2. RDMBS es状态(“热”数据库的行为与“冷”数据库不同,小表的行为与大表不同)
  3. 实现:聚集索引或非聚集索引

Tags:

最近发表
标签列表