<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<!-- saved from url=(0042)http://www.chinaunix.net/jh/20/245137.html -->
<HTML><HEAD><TITLE>[精华] Informix入门之---空间管理 - ChinaUnix.net</TITLE>
<META http-equiv=Content-Type content="text/html; charset=gb2312">
<META
content=Linux,Freebsd,Solaris,Sco,HP-UX,IBM-AIX,cisco,oracle,java,cgi,mysql,perl,Apache,proFTP,Sendmail,Qmail,DNS,Squid,Rsync,SSL
name=keywords>
<META content=ChinaUnix.net name=description>
<STYLE type=text/css>H1 {
FONT-SIZE: 24px; MARGIN: 0px
}
TD {
FONT-SIZE: 14px
}
SELECT {
FONT-SIZE: 14px
}
INPUT {
FONT-SIZE: 14px
}
.content {
FONT-SIZE: 14px; LINE-HEIGHT: 130%; FONT-FAMILY: Tahoma,MS Shell Dlg,宋体
}
.l17 {
LINE-HEIGHT: 170%
}
.f24 {
FONT-SIZE: 24px
}
.f14 {
FONT-SIZE: 14px; LINE-HEIGHT: 130%
}
A:link {
COLOR: #0000ff
}
A:visited {
COLOR: #800080
}
A:active {
COLOR: #ff0000
}
A:hover {
COLOR: #ff0000
}
A.a02:link {
COLOR: #0000ff; TEXT-DECORATION: none
}
A.a02:visited {
COLOR: #0000ff; TEXT-DECORATION: none
}
A.a02:active {
COLOR: #ff0000; TEXT-DECORATION: none
}
A.a02:hover {
COLOR: #ff0000; TEXT-DECORATION: none
}
</STYLE>
<META content="MSHTML 6.00.2900.5626" name=GENERATOR></HEAD>
<BODY leftMargin=0 topMargin=5 marginwidth="0" marginheight="5">
<CENTER><!--导航start-->
<TABLE cellSpacing=0 cellPadding=0 width=760 border=0>
<TBODY>
<TR>
<TD>
<SCRIPT
src="[精华] Informix入门之---空间管理 - ChinaUnix_net.files/title.js"></SCRIPT>
</TD></TR></TBODY></TABLE><!--导航end--><!--头部结束--><!--通栏广告开始-->
<TABLE cellSpacing=0 cellPadding=0 width=760 border=0>
<TBODY>
<TR>
<TD height=2></TD></TR>
<TR>
<TD>
<SCRIPT
src="[精华] Informix入门之---空间管理 - ChinaUnix_net.files/jh_top.js"></SCRIPT>
</TD></TR></TBODY></TABLE><!--通栏广告结束-->
<TABLE height=30 cellSpacing=0 cellPadding=0 width=760 border=0>
<TBODY>
<TR>
<TD vAlign=center align=left><FONT color=#0000ff><A class=a02
href="http://www.chinaunix.net/">ChinaUnix首页</A> > <A class=a02
href="http://www.chinaunix.net/jh">精华文章</A> > <A class=a02
href="http://www.chinaunix.net/jh/20">Informix</A> > 正文</FONT> </TD>
<FORM name=_search action=http://search.chinaunix.net/cgi-bin/search
method='post"'>
<TD vAlign=center align=right><INPUT class=t2 name=key> <INPUT type=submit value=搜索 name=enter> </TD></FORM></TR></TBODY></TABLE>
<TABLE cellSpacing=0 cellPadding=0 width=760 border=0>
<TBODY>
<TR>
<TD height=3></TD></TR>
<TR>
<TD bgColor=#747474 height=1><IMG height=1
src="[精华] Informix入门之---空间管理 - ChinaUnix_net.files/c.gif"
width=1></TD></TR></TBODY></TABLE>
<TABLE cellSpacing=0 cellPadding=0 width=760 border=0>
<TBODY>
<TR>
<TD vAlign=top align=middle bgColor=#edf0f5 rowSpan=2><BR>
<TABLE cellSpacing=0 cellPadding=0 width="90%" border=0>
<TBODY>
<TR>
<TH class=f24><FONT color=#05006c>
<H1>[精华] Informix入门之---空间管理</H1></FONT></TH></TR>
<TR>
<TD>
<HR SIZE=1 bgcolor="#d9d9d9">
</TD></TR>
<TR>
<TD align=middle height=20>http://www.chinaunix.net 作者:<A
href="http://bbs.chinaunix.net/viewpro.php?uid=72182"
target=_blank>czw1413_cn</A> 发表于:2005-03-03
21:47:22</TD></TR>
<TR>
<TD align=middle height=30>【<A
href="http://bbs.chinaunix.net/post.php?action=reply&fid=20&tid=245137"
target=_blank>发表评论</A>】【<A
href="http://bbs.chinaunix.net/viewthread.php?tid=245137"
target=_blank>查看原文</A>】【<A
href="http://bbs.chinaunix.net/forumdisplay.php?fid=20">Informix讨论区</A>】【<A
href="javascript:window.close()">关闭</A>】 </TD></TR>
<TR>
<TD class=l17><FONT class=f14 id=zoom><!-- 正文begin -->
<TABLE style="TABLE-LAYOUT: fixed; WORD-WRAP: break-word"
cellSpacing=0 cellPadding=0 width="100%" border=0>
<TBODY>
<TR>
<TD><BR>Informix入门之---空间管理
<BR> 说起数据库就不能不说数据库的存储,说存储就不能不说数据库对空间的管理。这里我们主要谈的是IDS对空间的管理的相关问题。
<BR> 从物理上来说,IDS管理的主要是page,chunk;从逻辑上来说主要是extent,tablespace,dbsapce。连续的page组成extent,多个extent组成tablespace,dbspace用来逻辑的管理chunk,而每个tablespace又是建立在dbsapce上的。
<BR> Chunk:一个单位的物理磁盘空间,在9.4版本之前不应许超过2G。一个chunk由path,offset,size三部分组成。因此我们在使用onspaces命令来加chunk的时候这三个参数是必不可少的。理论上一个数据库服务器上最多有2048个存储块,但是实际上由UNIX内核规定的一个进程所能打开的文件数来确定的。如果是使用cooked file来做为存储,那么offset可以设置为0,如果使用raw device来做为存储,那偏移量不能为0,至少第一个CHUNK的offset不能为0。
<BR> Page:是一最基本的I/O单位。一个page的大小是由OS来决定的,有2K的,也有4K的。我们拿2K的来举例说明。一个page有2048个bit,页头由24bit组成,页尾有一个4bit的时间戳,也就是说每一个page剩余的空间只有2020个bit,另外在每一个page上还有一个槽表,一个槽表4bit,一条记录对应一个槽表,这样在每一个page上存放的记录数就可以定下来。说这些的目的是为了说明在我们建表的时候尽量表不要建的太大,有的表一条记录的大小就超过了一个page,这样在读取的效率上并不是太高。另外还有一个FILLFACTOR的参数决定了数据页的填充程度,如果此值设置的不是太合理,经常上现节点分裂的情况,那对表的读取效率肯定是有影响的。
<BR> Extent:是磁盘上连续page的一组集合。在每个extent内的page都是连续的,在表中默认的extent的大小是16K,extent&amp;的大小决定了表中数据存放的集中程度。如果数据存放的过与分散在做磁盘I/O的时间肯定会变长,一般的情况下每个表的extent的大小建议不要超过50,如果太大,就需要做合理的调整。另外不能不提的是在随着extent数目的增长,每次分出的空间的大小是不不一样的,在每到16的时候,就翻倍。例如第一个extent是16K,第17个extent就是32K,第33个就是64K了,在翻倍的增长。
<BR> Tablespace:是extent的逻辑集合。各个extent在物理上不一定是连续的。
<BR> Dbspace:是一组chunk的逻辑集合。一般是把裸设备的chunk放在一个dbspace中,或者把一组熟文件放在一组chunk中,也有的把裸设备和熟文件放在一组dbspace中,但不建议这么做。
<BR> 其实在dbsapce中又有三类,一类就是一般的存放数据的dbsapce,另一类就是tempdbspace,还有一种是blobspace。第一种我就不说了。我们先说blobsapce.
<BR> Blobspace:blobspace是一组逻辑组织的chunk,但是是用来存储byte和text类型的数据。Blobspace中不能存放行或索引,只能存放存储了blob的页面和存储了关于BLOB的系统信息页面。因为blobspace中的BLOB页面的大小是在创建的时候指定的,所有一个blobspace中的所有BLOB页面大小相同。对BLOB的写,是没有在缓冲池中缓冲的,因此BLOB的值不写逻辑日志文件。当修改了BLOB的值之后,应该在磁盘上流出足够的空间以放BLOB的初始值和修改值。
<BR> Tempdbspace:是一组临时的dbspace。他在DBSPACETEMP参数中指定。需要在onspaces创建的时候加上-t的参数。对tempsaces的操作是不写逻辑日志的。在创建临时表和做group by ,order by,使用join语句,创建index的时候都是需要临时空间的。一般的情况下所有的tempspace的大小为正常业务数据的10%。如果太小了很大的操作就会出问题。
<BR>Select * from tab_a insert into temp tab_b是不写到tempdbspace的。
<BR>Select * from tab_a insert into temp tab_b with no log才写到tempdbspace。<BR><BR><BR>
<HR>
<B> <A
href="http://bbs.chinaunix.net/viewpro.php?uid=65341"
没有合适的资源?快使用搜索试试~ 我知道了~
informix资料

共34个文件
mht:33个
htm:1个

需积分: 9 35 浏览量
2008-10-19
19:44:34
上传
评论
收藏 438KB RAR 举报
我搜集到的informix培训资料,刚刚接触informix的朋友可以看看
资源详情
资源评论
资源推荐
收起资源包目录



































共 34 条
- 1






cerlcen
- 粉丝: 0
- 资源: 7

上传资源 快速赚钱
我的内容管理 收起
我的资源 快来上传第一个资源
我的收益
登录查看自己的收益我的积分 登录查看自己的积分
我的C币 登录后查看C币余额
我的收藏
我的下载
下载帮助

会员权益专享
安全验证
文档复制为VIP权益,开通VIP直接复制

评论0