V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
zxc1234
V2EX  ›  程序员

关于 oracle 表分区

  •  
  •   zxc1234 · 2020-06-15 07:45:46 +08:00 · 1783 次点击
    这是一个创建于 1623 天前的主题,其中的信息可能已经有所发展或是发生改变。

    请问

    1.表分区是要至少两台服务器吧?

    2.比如分了两个区 A 区和 B 区,那么会有备份机制吗,会有备份 A 区,备份 B 区吗?还是说比如 A 区挂了,A 区的数据就

    不能访问和读写了?

    3.我们说的垂直拆分是指分库?水平拆分是指表分区?

    谢谢~~

    8 条回复    2020-06-16 09:41:45 +08:00
    wd
        1
    wd  
       2020-06-15 07:48:24 +08:00 via iPhone
    表分区和服务器没关系。
    gz233
        2
    gz233  
       2020-06-15 09:02:12 +08:00
    1. 不需要。本地 `PARTITION BY RANGE, VALUES LESS THAN` 语句就可以测试
    2. 可以备份。分区是对表里指定列设定多个连续范围(实实在在的物理文件),满足某一范围就放入对应篮子里
    3. 垂直差分和水平差分都可以分库或分表,和分区概念不同。
    ---
    分区只是分开存放**一张表**的数据,篮子里放的数据结构都是一样的
    sonice
        3
    sonice  
       2020-06-15 09:50:11 +08:00
    表分区是类似于 sharding,不是 replica
    dog82
        4
    dog82  
       2020-06-15 10:32:50 +08:00
    楼主说的是 partition table 吧,普通的 mysql oracle 都能做,数据还是一份没冗余。记得建分区索引
    saulshao
        5
    saulshao  
       2020-06-15 16:44:03 +08:00
    3. 垂直拆分指的是将一个 100 字段的表拆成 2 个表,每个表包含 50 个字段。
    水平拆分则是典型的 Oracle 里面的表分区的概念。是按照行来拆分,例如某个字段有 10 个可枚举的值,每个值都拆分出一个表来,就变成 10 个表,注意这 10 个表的字段名字和原来的那一个表都是一致的
    zxc1234
        6
    zxc1234  
    OP
       2020-06-15 22:59:54 +08:00
    @dog82 请问数据没冗余,一个分区挂了,那个分区的数据就不能读写了?
    zxc1234
        7
    zxc1234  
    OP
       2020-06-15 23:03:58 +08:00
    @sonice 所以没有数据冗余了?一个分区挂了,那个分区的数据就不能读写了?
    sonice
        8
    sonice  
       2020-06-16 09:41:45 +08:00
    对的,Oracle 的东西没那么脆弱吧。除非你搞磁盘文件。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1787 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 16:26 · PVG 00:26 · LAX 08:26 · JFK 11:26
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.