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我们也能查询出对应的记录。
    ............................................................................................................................................
    以上个人见解,仅供参考,不足之处请多指教。
    ............................................................................................................................................

  • 相关阅读:
    【转】HTTP协议/IIS 原理及ASP.NET运行机制浅析【图解】
    【转】windows server 2012 R2搭建IIS服务器
    【转】新建网站(CodeFile)与新建Web应用(Codebehind)的区别
    微信小程序前端坑
    开题报告
    十大API网站
    animate使用方法
    简易音乐小程序
    如何在app.js 和其他页面中更改globalData的值
    qq音乐解析API
  • 原文地址:https://www.cnblogs.com/LoveShare/p/14430769.html
Copyright © 2011-2022 走看看