WEB开发网      婵犵數濮烽弫鍛婄箾閳ь剚绻涙担鍐叉搐绾剧懓鈹戦悩瀹犲闁汇倗鍋撻妵鍕箛閸洘顎嶉梺绋款儑閸犳劙濡甸崟顖氬唨闁靛ě浣插亾閹烘鈷掗柛鏇ㄥ亜椤忣參鏌″畝瀣暠閾伙絽銆掑鐓庣仭缁楁垿姊绘担绛嬪殭婵﹫绠撻、姘愁樄婵犫偓娴g硶鏀介柣妯款嚋瀹搞儱螖閻樺弶鍟炵紒鍌氱Ч瀹曟粏顦寸痪鎯с偢瀵爼宕煎☉妯侯瀳缂備焦顨嗗畝鎼佸蓟閻旈鏆嬮柣妤€鐗嗗▓妤呮⒑鐠団€虫灀闁哄懐濮撮悾鐤亹閹烘繃鏅濋梺闈涚墕濡瑩顢欒箛鏃傜瘈闁汇垽娼ф禒锕傛煕閵娿儳鍩f鐐村姍楠炴﹢顢欓懖鈺嬬幢闂備浇顫夊畷妯肩矓椤旇¥浜归柟鐑樻尭娴滃綊姊虹紒妯虹仸闁挎洍鏅涜灋闁告洦鍨遍埛鎴︽煙閼测晛浠滃┑鈥炽偢閹鈽夐幒鎾寸彇缂備緡鍠栭鍛搭敇閸忕厧绶炴俊顖滅帛濞呭洭姊绘担鐟邦嚋缂佽鍊垮缁樼節閸ャ劍娅囬梺绋挎湰缁嬫捇宕㈤悽鍛婄厽閹兼番鍨婚埊鏇㈡煥濮樿埖鐓熼煫鍥ュ劤缁嬭崵绱掔紒妯肩畺缂佺粯绻堝畷姗€濡歌缁辨繈姊绘担绛嬪殐闁搞劋鍗冲畷顖炲级閹寸姵娈鹃梺缁樻⒒閳峰牓寮崒鐐寸厱闁抽敮鍋撻柡鍛懅濡叉劕螣鐞涒剝鏂€闂佺粯鍔曞Ο濠囧吹閻斿皝鏀芥い鏃囨閸斻倝鎽堕悙鐑樼厱闁哄洢鍔屾晶顖炴煕濞嗗繒绠婚柡灞界Ч瀹曨偊宕熼鈧▍锝囩磽娴f彃浜炬繝銏f硾椤戝洨绮绘ィ鍐╃厵閻庢稒岣跨粻姗€鏌ㄥ☉妯夹fい銊e劦閹瑩顢旈崟顓濈礄闂備浇顕栭崰鏍礊婵犲倻鏆﹂柟顖炲亰濡茶鈹戦埄鍐ㄧ祷妞ゎ厾鍏樺璇测槈閵忕姈鈺呮煏婢跺牆鍔撮柛鏂款槺缁辨挻鎷呯粙搴撳亾閸濄儳鐭撶憸鐗堝笒閺嬩線鏌熼崜褏甯涢柡鍛倐閺屻劑鎮ら崒娑橆伓 ---闂傚倸鍊搁崐鐑芥倿閿旈敮鍋撶粭娑樺幘濞差亜鐓涢柛娑卞幘椤斿棝姊虹捄銊ユ珢闁瑰嚖鎷�
开发学院数据库MSSQL Server Microsoft SQL Server 2000 中查询优化器使用的统... 阅读

Microsoft SQL Server 2000 中查询优化器使用的统计

 2007-05-15 09:26:07 来源:WEB开发网 闂傚倸鍊搁崐椋庢濮橆兗缂氱憸宥堢亱闂佸湱铏庨崰鏍不椤栫偞鐓ラ柣鏇炲€圭€氾拷闂傚倸鍊搁崐椋庣矆娓氣偓楠炲鏁撻悩鎻掔€梺姹囧灩閻忔艾鐣烽弻銉︾厵闁规鍠栭。濂告煕鎼达紕校闁靛洤瀚伴獮鎺楀箣濠靛啫浜鹃柣銏⑶圭壕濠氭煙閻愵剚鐏辨俊鎻掔墛缁绘盯宕卞Δ鍐冣剝绻涘畝濠佺敖缂佽鲸鎹囧畷鎺戭潩閹典焦鐎搁梻浣烘嚀閸ゆ牠骞忛敓锟�婵犵數濮烽弫鍛婃叏椤撱垹绠柛鎰靛枛瀹告繃銇勯幘瀵哥畼闁硅娲熷缁樼瑹閳ь剙岣胯鐓ら柕鍫濇偪濞差亜惟闁宠桨鑳堕崝锕€顪冮妶鍡楃瑐闁煎啿鐖奸崺濠囧即閵忥紕鍘梺鎼炲劗閺呮稒绂掕缁辨帗娼忛埡浣锋闂佽桨鐒﹂幑鍥极閹剧粯鏅搁柨鐕傛嫹闂傚倸鍊搁崐椋庢濮橆兗缂氱憸宥堢亱闂佸湱铏庨崰鏍不椤栫偞鐓ラ柣鏇炲€圭€氾拷  闂傚倸鍊搁崐鐑芥嚄閼哥數浠氱紓鍌欒兌缁垶銆冮崨鏉戠厺鐎广儱顦崡鎶芥煏韫囨洖校闁诲寒鍓熷铏圭磼濡搫顫嶅銈嗗姉閸樠囧煡婢跺á鐔兼煥鐎n兘鍋撴繝姘拺鐟滅増甯掓禍浼存煕閹惧鈽夐柍缁樻煥椤繈鎳滅喊妯诲闂備礁鎲$粙鎴︺偑閺夋垟鏋旈柡鍐e亾缂佺粯绋撴禒锕傚磼濮橆剦鐎抽梻浣哥-缁垶骞戦崶顒傚祦閻庯綆浜栭弨浠嬫煙闁箑澧い鏂垮€规穱濠囨倷椤忓嫧鍋撻弽褜娼栧┑鐘宠壘閸屻劎鎲歌箛娑樼疅闁圭虎鍠楅弲鎼佹煥閻曞倹瀚�
核心提示:Microsoft SQL Server 2000 中查询优化器使用的统计Microsoft? SQL Server? 2000 收集关于存储在数据库中的索引和列数据的统计信息,SQL Server 查询优化器使用这些统计信息来选择用于执行 INSERT、SELECT、DELETE 或 UPDATE 查询的最有效方案,

Microsoft SQL Server 2000 中查询优化器使用的统计

Microsoft? SQL Server? 2000 收集关于存储在数据库中的索引和列数据的统计信息。SQL Server 查询优化器使用这些统计信息来选择用于执行 INSERT、SELECT、DELETE 或 UPDATE 查询的最有效方案。本文说明了收集的数据类型、数据的存储位置以及用于创建、更新与删除统计的命令。默认情况下,SQL Server 2000 会自动创建和更新统计(当此类操作有用时)。本文也概括介绍了如何在不同的级别(索引、表和数据库)上更改这些默认值。

SQL Server 2000 中的统计数据

SQL Server 2000 既收集关于单个列的统计信息(单列统计),也收集关于成组的列的统计信息(多列统计)。关于一个统计对象的所有信息存储在 SYSINDEXES 表中一行的多个列中。计算列以及数据类型为 ntext、text 或 image 的列不能被指定为统计列。组成一个统计集的所有列的总宽度不能超过 900 字节。

SQL Server 2000 收集的统计信息

上次收集统计信息的时间(在 STATBLOB 中)。

表或索引中的行数(SYSINDEXES 中的 rows 列)。

表或索引所占用的页数(SYSINDEXES 中的 dpages 列)。

用于生成直方图和密度信息的行数(在 STATBLOB 中,将在下面讲解)。

平均键长(在 STATBLOB 中)。

单列直方图,包括步数(在 STATBLOB 中)。

注意: 直方图是给定列的最多 200 个值的集合。给定列中的所有值(如果通过抽样来收集统计信息,则为选定的值)会被排序;排序后序列最多会划分为 199 个间隔,以便得到最有效的统计。一般,这些间距的大小并不相等。以下数值与直方图的每个步长存储在一起。

表 1:直方图的值

RANGE_HI_KEY键值
EQ_ROWS指定与 RANGE_HI_KEY 精确相等的行数。
RANGE_ROWS指定区间中的行数。(这些行小于这个 RANGE_HI_KEY,但大于上一个较小的区间键值)。
DENSITY指定 1/n,其中 n 表示区间中互不相同的值的数目。

使用 dbcc show_statistics 命令时显示的是两个导出值而不是 DENSITY 信息。

表 2:用两个导出值显示 dbcc show_statistics 的直方图

DISTINCT_RANGE_ROWS指定此区间中互不相同的行的数目(不算 RANGE_HI_KEY 值本身);DISTINCT_RANGE_ROWS = 1 / DENSITY。
AVG_RANGE_ROWS区间中每个特定值的平均行数;AVG_RANGE_ROWS = DENSITY * RANGE_ROWS。

SQL Server 2000 中的直方图只用于单个列、多列统计中的第一列或者索引。

SQL Server 2000 按照三个步骤从排序后的列值集合生成直方图。第一步,最多收集 200 个 RANGE_HI_KEY、EQ_ROWS、RANGE_ROWS 和 DISTINC_RANGE_ROWS 的值。第二步,对每个其他的列值进行处理:该值或者被添加到上一个区间中(对值进行排序),或者创建一个新区间。如果是创建一个新区间,则两个现有的相邻区间会合并到一个区间中。SQL Server 2000 通过密度信息来选择要合并的区间,使密度最接近的两个相邻区间被合并,从而将信息的损失降到最低程度。第三步,合并更多的密度接近的区间。因此,即使列中的唯一值个数超过 200,直方图的步数也可能会小于 200。

如果通过抽样来生成直方图,那么 RANGE_ROWS、EQ_ROWS、DISTINCT_RANGE_ROWS 和 AVG_RANGE_ROWS 的值将为估计值,因此它们不必都是整数。

密度是关于给定列或列的组合中重复项数目的信息,其计算公式为 1/(互不相同的值的数目)。如果在相等条件判断表达式中使用了某个列,则会使用从直方图导出的密度来估算符合条件的行数。直方图通常用于估算不等条件判断表达式。

注意: dbcc show_statistics 的第一行中会显示一个单独的密度值,但 SQL Server 2000 中的优化器不使用该值。

一个列集合的多列统计包括以下信息:统计定义中第一个列的直方图,第一个列的密度值,以及每个列的前缀组合(单独包括第一个列)的密度值。每个统计集(一个直方图加上两个或多个密度值)都存储在 SYSINDEXES 表的一行中,同一行中还包括上次更新统计的时间戳、用于生成统计信息的抽样行数、直方图的步数和平均键数。SQL Server 2000 只为编号为 0 或 1 的索引(堆索引或群集索引)维护行数的值(rowcnt 列),并在表中的所有索引中复制该值。同样,SQL Server 2000 也为每个表和索引维护 dpages。如果收集统计信息时表中没有任何行,则该表的统计信息为空。

使用 sp_helpindex 和 sp_helpstats 可以显示给定表中所有可用统计的列表,sp_helpindex 列出了表中的所有索引,而 sp_helpstats 则列出了表中的所有统计。每个索引都带有其中列的统计信息。在相同的列中,使用 CREATE STATISTICS 命令创建的统计信息与使用 CREATE INDEX 命令生成的统计信息等价。唯一的差别在于,CREATE STATISTICS 命令默认采用抽样方式,而 CREATE INDEX 命令则由于必须处理索引的所有行,因而使用 fullscan 收集统计信息。

下面是罗斯文数据库中 Order Details 表的所有索引和统计的示例。因为最初无索引的列上没有任何统计信息,所以在连接到罗斯文数据库后,请先运行 sp_createstats。

表 3:罗斯文数据库中的 Order Details 表

sp_helpindex [Order Details]

index_nameindex_descriptionindex_keys
OrderIDPRIMARY 上的非群集索引OrderID
PK_Order_DetailsPRIMARY 上群集的唯一主键OrderID、ProductID
ProductIDPRIMARY 上的非群集索引ProductID

sp_helpstats [Order Details]

statistics_namestatistics_keys
DiscountDiscount
QuantityQuantity
UnitPriceUnitPrice

也可以象下面这样使用 dbcc show_statistics 命令来显示统计信息:

dbcc show_statistics ([Order Details],PK_Order_Details)

如果没有返回任何信息,则表明上次已经更新了统计,或在表中没有任何行时就创建了索引。要更新 Order Details 表的统计,请运行 UPDATE STATISTICS [Order Details];要更新罗斯文数据库中所有表的统计,请运行 sp_updatestats。

注意: 该命令的输出已经增强了可读性。

关于 INDEX 'PK_Order_Details' 的统计信息

表 4:关于 INDEX 'PK_Order_Details' 的统计信息

更新时间

行数

抽样的行数

步数

密度

平均

键长

2000 年 5 月 17 日下午 10:38215521551921.1090337E-38.0

所有密度平均长度
1.2048193E-34.0OrderID
4.6403712E-48.0OrderID、Product ID

RANGE

_HI_KEY

RANGE_ROWS

EQ_ROWS

DISTINCT_RANGE

_ROWS

AVG_RANGE

_ROWS

102480.03.000.0
1025311.03.042.75
102567.02.023.5
102608.04.022.6666667
102635.04.022.5
102675.03.031.6666666
1027310.05.052.0
102788.04.042.0
102839.04.042.25
102867.02.023.5
102907.04.032.3333333
102948.05.022.6666667
102986.04.032.0
103039.03.042.25
103066.03.023.0
103094.05.022.0
103124.04.022.0
1031911.03.051.8333334
1032511.05.042.2
1032910.04.033.3333333
103336.03.032.0
103377.05.032.3333333
1034210.04.042.5
1034710.04.042.5
103515.04.031.6666666
1035711.03.042.2
103606.05.023.0
103635.03.022.5
103689.04.042.25
103726.04.032.0
103754.02.022.0
103807.04.041.75
103849.02.033.0
103875.04.022.5
103907.04.023.5
103932.05.021.0
103965.03.022.5
1040111.04.042.75
104057.01.032.3333333
104088.03.024.0
104127.01.032.3333333
1041710.04.042.5
104206.04.023.0
104247.03.032.3333333
104296.02.041.5
104327.02.023.5
1043710.01.042.5
104407.04.023.5
104446.04.032.0
104462.04.012.0
1045110.04.042.5
104557.04.032.3333333
104583.05.021.5
104615.03.022.5
104658.05.022.6666667
104709.03.042.25
104746.04.032.0
104799.04.042.25
1048510.04.052.0
1049010.03.042.5
104947.01.032.3333333
104987.03.032.3333333
1050410.04.052.0
105073.02.021.5
105128.04.042.0
105158.05.024.0
105199.03.033.0
105225.04.022.5
105244.04.014.0
105287.03.032.3333333
105303.04.013.0
105359.04.042.25
105374.05.014.0
1054110.04.033.3333333
105467.03.041.75
105507.04.032.3333333
105535.05.022.5
105554.05.014.0
105583.05.021.5
1056410.03.052.0
105688.01.022.6666667
105726.04.032.0
105757.04.023.5
105773.03.013.0
1058310.03.052.0
105873.03.031.0
105928.02.042.0
105968.03.022.6666667
1060515.04.081.875
106073.05.013.0
106128.05.042.0
106166.04.032.0
106218.04.042.0
106232.05.012.0
106266.03.023.0
1063414.04.072.0
1063911.01.042.75
106436.03.032.0
106465.04.022.5
106506.03.032.0
106546.03.032.0
106574.06.022.0
1066311.03.042.2
106666.02.023.0
106706.05.032.0
106748.01.022.6666667
106776.02.023.0
106805.03.022.5
106836.01.023.0
106866.02.023.0
106919.05.042.25
1069611.02.042.75
106984.05.014.0
1070926.03.0102.5999999
1071411.05.042.75
1072218.04.072.5714285
1073324.03.092.4000001
1074012.04.062.0
107456.04.041.5
107474.04.014.0
107519.04.033.0
107569.04.042.25
107597.01.023.5
107625.04.022.5
107666.03.032.0
107695.04.022.5
1077611.04.051.8333334
107816.03.041.5
1078915.04.072.1428571
107937.02.032.3333333
107964.04.022.0
108006.03.032.0
108036.03.023.0
108065.03.022.5
108117.03.041.75
108145.04.022.5
108187.02.032.3333333
108237.04.041.75
1082910.04.052.0
108328.04.024.0
108367.05.032.3333333
108397.02.023.5
108426.04.023.0
108467.03.032.3333333
108486.02.016.0
108515.04.022.5
108556.04.032.0
108585.03.022.5
108615.05.022.5
108668.03.042.0
108694.04.022.0
108725.04.022.5
1087810.01.052.0
108827.03.032.3333333
108854.04.022.0
108908.03.042.0
108947.03.032.3333333
1090315.03.081.875
109097.03.051.4
109126.02.023.0
1091710.02.042.5
1092310.03.052.0
109265.04.022.5
109308.04.022.6666667
109348.01.022.6666667
1094627.03.0102.4545455
109494.04.022.0
109548.04.042.0
1095910.01.042.5
109624.05.022.0
1096810.03.052.0
109735.03.041.25
109774.04.021.3333334
1098010.01.025.0
1098611.04.042.2
109908.04.022.6666667
1099710.03.061.6666666
1100110.04.033.3333333
1101124.02.082.6666667
110147.01.023.5
1101910.02.042.5
1102410.04.042.5
1103010.04.052.0
1103410.03.033.3333333
1103910.04.042.5
1105321.03.0131.6153846
1105810.03.042.5
1106411.05.042.2
1107010.04.052.0
110759.03.042.25
110760.03.000.0
110770.025.000.0
(共影响 192 行)

Tags:Microsoft SQL Server

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接