如何按年按月创建分区函数

yanheping02 2012-02-08 03:13:16
我创建了分区函数如下:
create partition function pf_month1(varchar(8))
as range left for values ('20120131','20120229','20120331','20120430','20120531','20120630','20120731','20120831','20120930','20121031','20121130')

但有一个问题,遇到跨年怎么处理?

如果到了2013年,所有的数据都会放在 最后一个分区里面,怎么处理?有没有更好一点的分区函数,按年按月进行分区?
...全文
181 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
AcHerat 元老 2012-02-08
  • 打赏
  • 举报
回复
假定现在的分区边界是 100 200 300 400
也就是


<100 200~300 300~400 >400

增加一个边界是500的分区


--指定下一个分区应用文件组.(如:PRIMARY)
ALTER PARTITION SCHEME [customer_scheme] --分区架构
NEXT USED [PRIMARY]

--指定分区分界点为
ALTER PARTITION FUNCTION customer_partFunc() --分区函数
SPLIT RANGE (500)


新分区后

<100 100~200 200~300 300~400 400~500 >500

如果再出现600的边界,可以继续按上边的样子来添加。
yanheping02 2012-02-08
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 acherat 的回复:]

按月来做分区是不是太奢侈了,数据量很多?还是磁盘很多呢?两年就是24个了。。。
[/Quote]
我一个月的数据量很大,800G左右,如果不分区的话,数据库以后就没法导出来了,以后换服务器,备份数据库都是问题。还有感谢帮忙,我还是没太看懂split.
AcHerat 元老 2012-02-08
  • 打赏
  • 举报
回复
按月来做分区是不是太奢侈了,数据量很多?还是磁盘很多呢?两年就是24个了。。。
AcHerat 元老 2012-02-08
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 yanheping02 的回复:]

我看了,不满足我的需求啊。
我想把戏2013年1月的数据放到第一个分区中,2013年2月的数据放到第二个分区中,依次。
[/Quote]

就是多添加几次边界,到2013年1月了,做次split,2月了再做一次,类似。
-晴天 2012-02-08
  • 打赏
  • 举报
回复
1.用每月1号做分区边界比较好,省得判断各月的天数.
2.分区是用来加快查询的,但各分区最好是独立的物理磁盘,放在同一个物理盘上,并不能增加许多性能.
3.如果按月分区,说明每月的数据量非常大,如果这样,则满一个月后修改分区函数即可,而不是一下子把所有分区都划分好.
4.如果满一个月后,前面某些月的数据使用量不大,则可以合并,这样只要把分区重新划分一下即可.
yanheping02 2012-02-08
  • 打赏
  • 举报
回复
我看了,不满足我的需求啊。
我想把戏2013年1月的数据放到第一个分区中,2013年2月的数据放到第二个分区中,依次。
AcHerat 元老 2012-02-08
  • 打赏
  • 举报
回复
你去搜下分区里是switch merge 和 split的操作就知道了。
至于你的问题应该是分区的拆分,也就是split操作。
yanheping02 2012-02-08
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 acherat 的回复:]

可以去切换 合并 或 拆分分区做处理。
[/Quote]
我要具体的操作啊,我对分区这块不太会。
AcHerat 元老 2012-02-08
  • 打赏
  • 举报
回复
可以去切换 合并 或 拆分分区做处理。

34,590

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧