首页
论坛
门户
空间
手机版
IXPUB
插件
收藏
设置
注册
登录
商店
搜索
培训
Wiki
Blog
归档
丛书
退出
ITPUB论坛
»
Sybase管理与开发
» 神奇的APL表
‹‹ 上一主题
|
下一主题 ››
30
2/3
‹‹
1
2
3
››
投票
交易
悬赏
活动
评价
|
打印
|
推荐
|
订阅
|
收藏
标题:
[精华]
神奇的APL表
beginner_bj
资深会员
精华贴数 2
个人空间
0
技术积分 2110 (732)
社区积分 11 (9816)
注册日期 2002-4-2
论坛徽章:2
#11
使用道具
发表于 2007-7-27 00:07
1、不管是什么数据库的什么表,只要表上有聚簇索引,那对表做reorg的时候一定要会让记录按聚簇索引重新排序(前提当然是这种表支持reorg),不按聚簇索引排序的reorg还不如不做。至于这是不是目的,那要看从哪个角度来说了。
2、我说DOL表在“范围查询”上有优势是说:如果查询结果较多时(比如一个页能放100条记录,而查询结果是500条),刚做过reorg的DOL表肯定效率最高,分析过程就是从I/O角度来着手的。
3、假如APL表上有聚簇索引,又假如一个页能放100条记录,且正好放满了100条记录,那么新insert一条记录,比如正好位于60、61之间,不仅会导致页的分裂,而且这个页的后40条记录都会挪一遍。我说APL表的这种行为可以看作是reorg。假如这个页后来又插入了一条记录(每次insert都当作一个事物),那么又会引起许多记录的挪动。这样挪动了M次,前M-1次都可以认为是白做。(delete/update的时候会怎样,我没想过,暂且不提)
4、多说一条:我认为,APL表不是不需要reorg,而是它不支持reorg,想做,但没办法做。
个人看法,望指正。
__________________
BLOG : http://www.cublog.cn/u/739/http://www.loveunix.net/discuz/forumdisplay.php?fid=70&page=1
只看该作者
jarjar
新人,请多关照
精华贴数 1
个人空间
0
技术积分 4321 (309)
社区积分 166 (2540)
注册日期 2005-6-1
论坛徽章:20
#12
使用道具
发表于 2007-7-27 10:08
1、APL表的聚簇索引
保证
数据的排列是按照索引的顺序来排列。APL索引树的页节点就是数据。因此在范围查询结果时,当通过索引定位到第一条纪录时,后续的结果集可以直接通过页链查找,不再需要从索引定位到页,再定位到纪录。
2、DOL表上的聚簇索引
不保证
数据的排列是按照索引的顺序来排列(不管是不是做了reorg)。因此在范围查询的方式下,每条符合条件的纪录都只能通过索引来进行定位,而不能像APL表一样,直接通过页链来向下搜索,这两种方式的I/O是不同的。
3、举个例子来说明上述情况:一张表,每一个数据页上保存100条纪录,每个索引页上保存1000条纪录,索引树深度为3,现在一条SQL语句查询的结果纪录条数为1000条。在APL表的查询IO次数为:1(index root page)+1(index Intermediate page)+1000/100(由于数据是按索引顺序排序,因此直接按照页链向下读10页就可以得到符合条件的1000条纪录)=12。而DOL表的查询IO次数为:1(index root page)+1(index Intermediate page)+1(index leaf page)+1000(由于DOL不保证所有的数据是按照索引的顺序排列,因此只能从索引定位到页,所以有1000页IO)=1003。
所以,APL表的聚簇索引在范围查询(纪录集为多条的时候),比DOL表的聚簇索引有优势。
但是由于APL表要维持数据按照聚簇索引的顺序来排列,因此当聚簇索引的列选择不合适的时候,会导致insert/delet/update的效率降低(因为会导致页的分裂或者合并)。
__________________
if you want something done right, hire a professional
只看该作者
jarjar
新人,请多关照
精华贴数 1
个人空间
0
技术积分 4321 (309)
社区积分 166 (2540)
注册日期 2005-6-1
论坛徽章:20
#13
使用道具
发表于 2007-7-27 10:16
DOL表上的聚簇索引并不保证数据会按照索引的顺序排列(而APL表的聚簇索引是严格保证数据按照聚簇索引的顺序排列),而reorg的目的是因为DOL表的页结构导致。DOL表为了保证大并发下的insert/update/delete,因此它的页结构和APL表的页结构不同,而这种结构导致数据在频繁的insert/update/delete后,空间的浪费会比较严重,而reorg是为了整理回收空间而使用的,并不是为了使数据保持聚簇索引的顺序(DOL的聚簇索引并不要求数据按索引顺序排列)。
__________________
if you want something done right, hire a professional
只看该作者
jarjar
新人,请多关照
精华贴数 1
个人空间
0
技术积分 4321 (309)
社区积分 166 (2540)
注册日期 2005-6-1
论坛徽章:20
#14
使用道具
发表于 2007-7-27 10:17
Clustered indexes on data-only-locked tables are structured like nonclustered
indexes. They have a leaf level above the data pages. The leaf level contains
the key values and row ID for each row in the table.
Unlike clustered indexes on allpages-locked tables, the data rows in a dataonly-
locked table
are not necessarily maintained in exact order by the key
.
Instead, the index directs the placement of rows to pages that have adjacent or
nearby keys.
请仔细阅读我给你推荐的书上的内容。
__________________
if you want something done right, hire a professional
只看该作者
1017of
新手上路
精华贴数 0
个人空间
0
技术积分 46 (28657)
社区积分 81 (3730)
注册日期 2002-11-23
论坛徽章:0
#15
使用道具
发表于 2007-7-27 10:26
观望
只看该作者
jarjar
新人,请多关照
精华贴数 1
个人空间
0
技术积分 4321 (309)
社区积分 166 (2540)
注册日期 2005-6-1
论坛徽章:20
#16
使用道具
发表于 2007-7-27 10:44
QUOTE:
最初由 1017of 发布
观望
把灌水的拖出去。磨树。
__________________
if you want something done right, hire a professional
只看该作者
beginner_bj
资深会员
精华贴数 2
个人空间
0
技术积分 2110 (732)
社区积分 11 (9816)
注册日期 2002-4-2
论坛徽章:2
#17
使用道具
发表于 2007-7-27 20:46
我中午敲的字呢?怎么都不见了?
难道我当时没发吗?
__________________
BLOG : http://www.cublog.cn/u/739/http://www.loveunix.net/discuz/forumdisplay.php?fid=70&page=1
只看该作者
jarjar
新人,请多关照
精华贴数 1
个人空间
0
技术积分 4321 (309)
社区积分 166 (2540)
注册日期 2005-6-1
论坛徽章:20
#18
使用道具
发表于 2007-7-30 10:04
QUOTE:
最初由 beginner_bj 发布
我中午敲的字呢?怎么都不见了?
难道我当时没发吗?
那就再发一遍了。
__________________
if you want something done right, hire a professional
只看该作者
beginner_bj
资深会员
精华贴数 2
个人空间
0
技术积分 2110 (732)
社区积分 11 (9816)
注册日期 2002-4-2
论坛徽章:2
#19
使用道具
发表于 2007-7-31 01:49
1、APL表的聚簇索引保证 数据的排列是按照索引的顺序来排列_
——APL表的聚簇索引只保证同一页上数据的排列是按照索引的顺序来排列,数据若分布在多个页上,是肯定不保证按顺序排列的。
2、DOL表上的聚簇索引不保证 数据的排列是按照索引的顺序来排列(不管是不是做了reorg)
——你可以看看reorg rebuild
3、DOL表的查询IO次数为:1(index root page)+1(index Intermediate page)+1(index leaf page)+1000
——最后这个+1000,我不能肯定,不知道有没有方法可以监控到实际的IO次数?如果有办法,那就拿刚reorg过的DOL表测一下。
4、13楼
——还是reorg rebuild
5、dataonly-locked table are not necessarily maintained in exact order by the key.
——不必要(not necessarily)不表示不能
另外,
只说APL表,SELECT语句用到聚簇索引和只用到非聚簇索引,其它条件类似,会不会差别真的很大?
还是APL表,举个极端的例子,如果页为2K,行长大于1024,即一个数据页只能放一行,IO次数的计算又会怎样?
上面只说了SELECT的情况,对于INSERT/DELETE等情况,APL表显然很有劣势。重申一下我的观点——SELECT时APL表优势不明显,INSERT/DELETE时APL表劣势很突出。(当然,SELECT时APL表优势明不明显,还需要用测试数据说话)
__________________
BLOG : http://www.cublog.cn/u/739/http://www.loveunix.net/discuz/forumdisplay.php?fid=70&page=1
只看该作者
beginner_bj
资深会员
精华贴数 2
个人空间
0
技术积分 2110 (732)
社区积分 11 (9816)
注册日期 2002-4-2
论坛徽章:2
#20
使用道具
发表于 2007-7-31 01:50
白天太忙了,下次回帖要到明天晚上了。
怎么没有其他人参与讨论?
__________________
BLOG : http://www.cublog.cn/u/739/http://www.loveunix.net/discuz/forumdisplay.php?fid=70&page=1
只看该作者
30
2/3
‹‹
1
2
3
››
投票
交易
悬赏
活动
相关内容
ITPUB论坛
≡ 数据库技术 ≡
> Oracle数据库管理
> Oracle开发
> Oracle Developer Suite
> Oracle入门与认证
> Oracle专题深入讨论
> Oracle新技术/11g
> Oracle电子文档
> Oracle Application Server套件
> IBM数据库产品
> MS SQL Server
> Sybase管理与开发
> MySQL及其它开源数据库
> 内存数据库
> 数据仓库与数据挖掘
> 移动及嵌入式数据库
≡ 企业信息化 ≡
> ERP产品与实践
> CRM产品与实践
> HR产品与实践
> 物流
> 供应链
> 供应链建模与仿真
> 物流设备与系统工程
> 企业管理咨询
> 管理协同与办公自动化
> IT服务管理
> 数据中心建设
> ERP二次开发
> Oracle ERP
> EBS相关文档
> PeopleSoft与JDE
> SAP R/3
> SAP Business One开发与快速实施
> SAP财务及CRM
> SAP后勤及HR
> mySAP ERP
> 系统开发及跨应用设置
> SAP相关文档
> 国外其它ERP产品
> 国内ERP产品
≡ 开发技术 ≡
> Java入门与认证版
> Java web开发及框架技术
> Java企业开发
> ASP.NET【已迁移到微软开发技术论坛】
> .Net企业开发与应用【已迁移到微软开发技术论坛】
> WEB程序开发
> WEB 2.0技术
> 动态语言
> 移动与游戏开发
≡ 系统设计与项目管理 ≡
> 系统分析与UML
> 系统分析与UML精华区
> 项目管理
> 项目过程
> 软件测试
> 算法讨论与研究
≡ IBM软件技术园地 ≡
> IBM数据库产品
> Lotus
> Tivoli
> Websphere
> Rational
> 与SOA相关的IBM产品与技术
> IBM软件技术精英协会
> 软件技术精英活动专版
≡ 操作系统与硬件 ≡
> AIX及IBM产品【已迁移到IXPUB】
> HP-UX及HP产品【已迁移到IXPUB】
> Solaris及SUN产品【已迁移到IXPUB】
> Linux及其应用 【已迁移到IXPUB】
> 其它UNIX系统【已迁移到IXPUB】
> windows系统及微软相关产品 【已迁移到IXPUB】
> 存储设备与容灾技术 【已迁移到IXPUB】
> 服务器 【已迁移到IXPUB】
≡ 行业纵向讨论区 ≡
> IT业界评论与展望
> 政府与教育事业
> 中国政府信息主管联盟
> 电信行业
> 金融行业
> 医卫行业
> 制造行业
> 电力行业
> 信息安全与审计
≡ 会员交流 ≡
> IT职业生涯
> 招聘求职商务信息
> 旅游,驴友
> 汽车世界
> 外语角
> 数码摄影
> 你的故事我的歌
> 音乐推荐区
> 电子图书与IT文档资料
> 软件交流
> 软件交流精华区
≡ ITPUB产品与服务 ≡
> ITPUB地面活动专版
> BLOG天地
> WIKI世界
> 授权用户区
> 站务管理
≡ 微软开发技术 ≡
> 开发工具和语言
> .NET Framework 相关
> Visual Basic/VB.net
> Visual C#
> Visual C++/vc.net
> Visual Studio
> .NET软件架构与模式
> .NET开发辅助工具及框架
> Web开发
> ASP.NET与AJAX
> Web相关讨论(IIS等)
> Silverlight 技术
> Office开发
> Microsoft office system
> Office Business Application
> 微软企业级产品技术
> windows server
> SharePoint
> Exchange Server
> Biztalk
> 嵌入式及移动开发
> Windows Embedded 嵌入式技术
> Windows 移动设备
> 微软产品用户交流区
> .Net电子书籍&&书籍介绍
> .Net人才交流
技术积分榜
社区积分榜
徽章
电子杂志
会员
团队
统计
邮箱
游乐场
帮助
TOP
CopyRight 1999-2006 itpub.net All Right Reserved.
北京皓辰广域网络信息技术有限公司. 版权所有
E-mail:Webmaster@itpub.net
京ICP证:010037号
联系我们
法律顾问
控制面板首页
编辑个人资料
积分交易
公众用户组
好友列表
升级个人空间
基本概况
论坛排行
主题排行
发帖排行
积分排行
在线时间
管理团队
管理统计