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

yumo6661个月前 (03-30)技术文章18

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. 实现:聚集索引或非聚集索引

相关文章

70道SQL经典面试题大全,看这一篇就够了

吐血整理了一周SQL面试题,包括了选择题、问答题、实战题。每道题都给大家加了详细的独家解析。几乎每个知识点都涉及到了。刷完这套题,关于SQL的面试妥妥的。题目来源:各大厂面试题、牛客网选择题(1)基础...

总结面试:SQL常见面试题-1

刚刚走过了金三银四,相信许多小伙伴已经得到了自己心仪的offer,在这里先恭喜大家啦!但可能还有一些小伙伴刚刚开始找工作,作为一名数据分析师,还是想总结一些面试的经验及SQL的笔试面试题给各位小伙伴,...

200场面试总结出的大厂SQL常考题(附答案)

小伙伴们,大家好。今天给大家分享一些在数据分析岗位面试中,常被问到的一些SQL题。首先,大家先思考一下题目,然后再看后面的参考答案。Q1:几种JOIN连接方式的区别?Q2:几种排序窗口函数的区别?Q3...

C#面试宝典 2022年 60个常见的C#面试问题和答案

我们整理了60个常见的C#面试问题和答案,包括初级,中级和高级面试问题。对即将参加面试的同学非常有用,建议收藏研读。许多雇主对只会纸上谈兵的程序员都保持持谨慎态度,特别是没有编程经验但而有学位的人。正...

大厂面试SQL题(三) ——连续登陆(含间隔)(字节)

承继上篇文章 大厂面试SQL题(一) ——连续登陆,阐述了最为简易的连续登录题目。然而,倘若在面试题目中增添难度,将 隔天统计问题 纳入考量,该作何处理呢?沿用第一篇题目的场景实例:(1)存在一张用户...