为什么在 SQL Server 中,临时表的连接速度比表变量快?
注意:在这两种情况下,表都有 PK,并且这些表通过 PK 与其他“物理”表连接。
为什么在 SQL Server 中,临时表的连接速度比表变量快?
注意:在这两种情况下,表都有 PK,并且这些表通过 PK 与其他“物理”表连接。
两者都保存在 Tempdb 中;然而,性能问题开始发挥作用,因为优化器不维护表变量的统计信息。这是有问题的,因为优化器总是会假设您的表变量中有 1 行。显然,这确实会搞砸查询计划,尤其是当表变量中有很多行时。我不会使用表变量来存储超过 1000 行左右的内容;否则,性能可能无法预测。
临时表与表类似,但创建时存储在 tempdb 中,这意味着优化器可以对它们创建统计信息,而表变量与变量类似,并且没有关于它们的统计信息。通常在比较 tmp 表与表变量时,临时表名列前茅。原因是查询优化器有时会为表变量生成糟糕的计划。当有大量数据时,通常可以看到这一点。我能说的最重要的一点是,与为临时表生成的计划相比,表变量更有可能导致不可预测的执行计划。另一方面,临时表会导致更多的重新编译。