我正在尝试创建一个查询执行计划的示例,它表明如果我对表的某些列进行基数估计,我可以决定哪个查询执行计划的成本最低。
所以我有这两篇文章(1和2),我可以将估计基数理解为列上不同值的数量。然后我计算选择性。
SELECT max(price) FROM tickets WHERE country = "CANADA";
Run Code Online (Sandbox Code Playgroud)
如果我的桌子有 180 件物品,而只有 10 件是加拿大的。而且只有 4 个不同的国家(加拿大、巴西、美国、德国)。所以....
列 country é 4的基数,因为它是不同项目的数量。
列 country = CANADA的选择性是访问的项目数除以表中的项目数。10/180 = 0.0555。
但是优化器可以根据基数选择哪些不同的查询执行计划?
如果这不是一个很好的例子,有人可以指出一个查询,基数对于优化器来说是一种财富,以便决定选择一个计划还是另一个计划?
谢谢,费利佩
sql-server optimization execution-plan cardinality-estimates