今天我们向大家讲述的是SQL Server 2000 数据仓库中使用分区之分区设计的简捷概述,SQL Server 数据库中的分区表主其可以使用可更新或者是可查询(不可更新)的分区视图。在这两种情况下,表分区都是由每个分区都包含正确数据的 CHECK 约束来创建的。
一个可更新的分区视图支持对视图进行 INSERT (或 UPDATE 或 DELETE)操作,并将操作推入至正确的基础表。这很有益处,但SQL Server 2000 数据仓库应用程序通常需要进行批量加载,而这是无法通过视图执行的。下表总结了可更新和可查询分区视图的要求、优点和缺点。
Microsoft 建议的做法是定义主键,并将事实表设计为本地(单个 服务器 上)的分区联合视图。大多数情况下,该定义会产生可更新的分区视图,但SQL Server 2000 数据仓库维护应用程序应设计为直接将大多数数据批量加载至成员表(而不是通过视图进行)。
语法示例:
以下代码示例用来说明定义成员表和联合视图以及将数据插入视图的语法:
创建 1999 年事实表:
创建 2000 年事实表:
创建 UNION ALL 视图:
现在插入几行数据,例如:
要验证分区是否正常工作,请使用查询分析器来显示查询计划,例如:
您应该看到查询计划中仅包括表 1999。将该查询计划与主键已删除的相同表生成的查询计划相比较,我们会发现:表 2000 仍然被排除。将这些计划与在已删除 date_key 约束的架构上生成的查询计划进行对比。这些约束被删除的情况下,表 1999 和表 2000 都被包括在查询中。
请注意,在通常情况下,在大型表上执行查询时,使用“TOP N”语法是好的做法,因为它可以迅速返回结果并使用最少的服务器资源。查看分区表的查询计划时,这一点尤为重要,因为由“SELECT *”语句生成的查询计划很难解析。对于偶尔进行观察的人而言,尽管在查询执行期间,查询中仅使用相关的表,但表面看起来好象查询计划包括了 UNION ALL 视图的所有组件表。
将条件直接应用于事实表:
要获得***的查询性能,所有的查询都应将条件直接放在事实表中的筛选键上。将约束放在第二张表(例如日期矢量表)的查询将包括所有分区。对 UNION ALL 事实表的标准星号联合查询工作良好,将条件放在任意未分区的矢量表的属性上,以标准方式创建星号查询 WHERE 子句,包括分区矢量(日期)的属性。
如果每一分区表的索引中的***个列为带日期的簇索引,转到所有分区解析某一特定查询的开销相对较小。编写预定义的查询时应尽可能提高其效率,例如那些生成标准报表或渐变更新下行数据流数据库的查询。 以上的相关内容就是对在SQL Server 2000 数据仓库中使用分区之分区设计概述 的介绍,望你能有所收获。
【编辑推荐】
如何在SQL SERVER 2000 用查询分析器设置???
EXEC sp_attach_db @dbname = Npubs, @filename1 = Nc:\Program Files\Microsoft SQL Server\MSSQL\Data\, @filename2 = Nc:\Program Files\Microsoft SQL Server\MSSQL\Data\pubs_
sql server 2008 输入命令没有反应

这个管理器中。 嗯,如果你安装了sql server 2008 ,可以 窗口键+ R 调出系统的RUN窗口,输入 就可以打开这个管理器了。
SQL 2000 中 grant 的用法
GRANT 名称 GRANT — 赋予一个用户,一个组或所有用户访问权限 语法 GRANT privilege [, ...] ON object [, ...]TO { PUBLIC | GROUP group | username } 输入 privilege 可能的权限有: SELECT 访问声明的表/视图的所有列/字段. INSERT 向声明的表中插入所有列字段. UPDATE 更新声明的表所有列/字段. DELETE 从声明的表中删除所有行. RULE 在表/视图上定义规则 (参见 CREATE RULE 语句). ALL 赋予所有权限. object 赋予权限的对象名.可能的对象是: table view sequence PUBLIC 代表是所有用户的简写. GROUP group 将要赋予权限的组 group . username 将要赋予权限的用户名.PUBLIC 是代表所有用户的简写. 输出 CHANGE 如果成功,返回此信息. ERROR: ChangeAcl: class object not found 如果所声明的对象不可用或不可能对声明的组或用户赋予权限. 描述 GRANT 允许对象的创建者给某用户或某组或所有用户(PUBLIC)某些特定的权限.对象创建后,除了创建者外,除非创建者赋予(GRANT)权限,其他人没有访问对象的权限. 一旦用户有某对象的权限,他就可以使用那个特权.不需要给创建者赋予(GRANT)对象的权限,创建者自动拥有对象的所有权限,包括删除它的权限. 注意 目前,要想在 Postgres 里面只赋予几列权限,你必须创建一个包含那几列的视图(view),然后把权限赋予那几个视图。 使用 psql \z 命令获取关于现存对象权限的更多信息:Database = lusitania+------------------+---------------------------------------------+| Relation | Grant/Revoke Permissions |+------------------+---------------------------------------------+| mytable | {=rw,miriam=arwR,group todos=rw} |+------------------+---------------------------------------------+Legend:uname=arwR -- privileges granted to a usergroup gname=arwR -- privileges granted to a GROUP=arwR -- privileges granted to PUBLICr -- SELECTw -- UPDATE/DELETEa -- INSERTR -- RULEarwR -- ALL 参考 REVOKE 语句废除访问权限. 用法 给所有用户向表 films 插入记录的权限: GRANT INSERT ON films TO PUBLIC; 赋予用户 manuel 操作视图 kinds 的所有权限: GRANT ALL ON kinds TO manuel; 兼容性 SQL92 SQL92 GRANT 语法允许对表中的某单独列/字段设置权限,并且允许设置一权限以赋予别人相同权限: GRANT privilege [, ...]ON object [ ( column [, ...] ) ] [, ...]TO { PUBLIC | username [, ...] } [ WITH GRANT OPTION ] 这些字段与 Postgres 实现是兼容的,除了下面一些例外: privilege SQL92 允许声明附加的权限: SELECT REFERENCES 允许在一个声明的表的完整性约束中使用某些或全部列/字段. USAGE 允许使用一个域,字符集,集合或事务.如果声明的对象不是表/视图, privilege 只能声明为 USAGE. object [ TABLE ] table SQL92 允许一个附加的非功能性关键字 TABLE. CHAracTER SET 允许使用声明的字符集. COLLATION 允许使用声明的集合序列. TRANSLATION 允许使用声明的字符集转换. DOMAIN 允许使用声明的域. WITH GRANT OPTION 允许向别人赋予同样权限.
发表评论