zoukankan      html  css  js  c++  java
  • 数据库分表自增ID问题

    ............................................................................................................................................
    假设我们对tbl进行分表:
    tbl_1、tbl_2
    并且tbl_1、tbl_2都使用自增ID,则可能出现自增ID重复问题:
    tbl_1:
    id
    1

    tbl_2:
    id
    1
    ............................................................................................................................................
    在进行业务处理时如果根据ID修改信息则可能会导致另一张子表相同ID的数据受到影响:
    update tbl
    set xx='test'
    where id =1 ;
    ............................................................................................................................................
    解决方案:
    1.通过修改步长并且为每张表设置不同的起始值即可实现:
    tbl_1:起始位置:1、步长:2
    tbl_2:起始位置:2、步长:2

    tbl_1中的id为:1、3、5、7、9...
    tbl_2中的id为:2、4、6、8、10...
    这样所有的子表ID都不会出现重复
    多张表同理
    2.通过设置分表规则对应表也可实现:
    假设
    tbl_1是所有性别为男的信息
    tbl_2是所有性别为女的信息
    则我们可以设置一张中间表:
    tbl_mid:
    性别 子表名称
    男 tbl_1
    女 tbl_2
    这样我们进行查询的时候通过性别就能确定到对应的子表,即便子表之间有重复ID我们也能查询出对应的记录。
    ............................................................................................................................................
    以上个人见解,仅供参考,不足之处请多指教。
    ............................................................................................................................................

  • 相关阅读:
    Linux内核调试方法总结之ftrace
    Linux内核调试方法总结之ptrace
    Linux内核调试方法总结之ltrace
    文件处理
    python基础之字符编码
    第三篇:python基础之数据类型与变量
    第二篇:python基础之核心风格
    数据类型、字符编码、文件处理
    python入门
    爬取加载页面数据
  • 原文地址:https://www.cnblogs.com/LoveShare/p/14430769.html
Copyright © 2011-2022 走看看