位置: 编程技术 - 正文

MySQL分表自增ID问题的解决方法(mysql分表命令)

编辑:rootadmin

推荐整理分享MySQL分表自增ID问题的解决方法(mysql分表命令),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql分表实现,mysql分表的3种方法,mysql分表命令,mysql分表语句,mysql innodb 分表,mysql增加表分区,mysql分表的3种方法,mysql分表语句,内容如对您有帮助,希望把文章链接给更多的朋友!

当我们对MySQL进行分表操作后,将不能依赖MySQL的自动增量来产生唯一ID了,因为数据已经分散到多个表中。   应尽量避免使用自增IP来做为主键,为数据库分表操作带来极大的不便。 在postgreSQL、oracle、db2数据库中有一个特殊的特性---sequence。 任何时候数据库可以根据当前表中的记录数大小和步长来获取到该表下一条记录数。然而,MySQL是没有这种序列对象的。 可以通过下面的方法来实现sequence特性产生唯一ID:

1. 通过MySQL表生成ID 对于插入也就是insert操作,首先就是获取唯一的id了,就需要一个表来专门创建id,插入一条记录,并获取最后插入的ID。代码如下:

MySQL分表自增ID问题的解决方法(mysql分表命令)

也就是说,当我们需要插入数据的时候,必须由这个表来产生id值,我的php代码的方法如下:

这种方法效果很好,但是在高并发情况下,MySQL的AUTO_INCREMENT将导致整个数据库慢。如果存在自增字段,MySQL会维护一个自增 锁,innodb会在内存里保存一个计数器来记录auto_increment值,当插入一个新行数据时,就会用一个表锁来锁住这个计数器,直到插入结 束。如果是一行一行的插入是没有问题的,但是在高并发情况下,那就悲催了,表锁会引起SQL阻塞,极大的影响性能,还可能会达到 max_connections值。 innodb_autoinc_lock_mode:可以设定3个值:0、1、2 0:traditonal (每次都会产生表锁) 1:consecutive (默认,可预判行数时使用新方式,不可时使用表锁,对于simple insert会获得批量的锁,保证连续插入) 2:interleaved (不会锁表,来一个处理一个,并发最高) 对于myisam表引擎是traditional,每次都会进行表锁的。

2. 通过redis生成ID

3. 队列方式 其实这也算是上面的一个解说 使用队列服务,如redis、memcacheq等等,将一定量的ID预分配在一个队列里,每次插入操作,先从队列中获取一个ID,若插入失败的话,将该ID再次添加到队列中,同时监控队列数量,当小于阀值时,自动向队列中添加元素。 这种方式可以有规划的对ID进行分配,还会带来经济效应,比如QQ号码,各种靓号,明码标价。如网站的userid, 允许uid登陆,推出各种靓号,明码标价,对于普通的ID打乱后再随机分配。

监控队列数量,并自动补充队列和取到id但并没有使用

标签: mysql分表命令

本文链接地址:https://www.jiuchutong.com/biancheng/347570.html 转载请保留说明!

上一篇:win2008 R2 WEB环境配置之MYSQL 5.6.22安装版安装配置方法(windows web server 2008)

下一篇:MySQL ERROR 1045 (28000) 错误的解决办法

  • 收到退回的以前年度租金怎么处理
  • 存在弃置费用的固定资产的财务费用
  • 无形资产加计扣除最新政策
  • 个体工商户怎么变更法人
  • 红字发票信息表填好后再怎么操作
  • 销售产品产生的运杂费分录
  • 一般纳税人兼营不同税率
  • 开票系统年费怎么缴纳
  • 企业收到宣传费怎么入账
  • 退货开负数发票的情况该如何做会计处理?
  • 筹建期土地使用税分录
  • 外币应收帐款汇兑损益现流附表
  • 出纳长短款项应按日结清,但不需要计算
  • 小企业税金及附加会计分录
  • 资管新规出台目的
  • 用人单位有残疾补贴吗
  • 行政单位以前年度会计错账调整
  • 生产企业的免抵退纳税申报,在财务做销售收入账务后
  • 企业清算期间账务怎么做
  • 卸载了驱动程序会怎么样
  • 王者荣耀中如何隐藏贵族标志
  • 解决网卡驱动故障的方法
  • 系统属性的表现
  • php获取指定日期的时间戳
  • 单位保洁外包公司收费标准
  • launcher process
  • 同城票据清算会怎么样
  • 转让土地使用权的条件是什么
  • 我国关税税则设有
  • 出口货物的出口日期以
  • 电子发票记账清单入账
  • 免交的增值税要交所得税吗
  • 其他货币资金明细科目有哪些
  • 消费税减免规定有哪些
  • React - Redux Hooks的使用细节详解
  • 预缴城建税税率
  • 收到股利的会计分录
  • mongodb bi
  • 水利基金的计税税率6
  • 事业单位净资产变动表
  • 原材料的帐务处理
  • 物业管理单位收取的物业费征不征收增值税
  • 没有进货发票可以开票吗?
  • 借款合同的印花税计税依据
  • 公益性捐赠要确认递延吗
  • 现金日记账金额怎么填写
  • Slave memory leak and trigger oom-killer
  • mysql 创建root用户和普通用户及修改删除功能
  • 苹果15手机价格和图片颜色
  • 苹果mac怎么下载英雄联盟
  • 安装win7系统需要注意什么
  • vmware安装centos7超详细过程 图文
  • linux ubuntu教程
  • 无光驱无u盘重装系统
  • xp启用telnet
  • windows7的管理在哪里
  • 怎样判断滚动和滑动
  • python tcp socket
  • BUG: OpenGL error 0x0500 in -[CCEAGLView swapBuffers] 328
  • opengl教程48讲
  • Android Bound Service(二) ----- Using AIDL
  • php 时间差
  • opencv for linux
  • js判断鼠标位置是否在元素区域内使用
  • node socket hang up
  • 防止sql注入php
  • js如何使用
  • jquery返回顶部代码
  • js中如何弹出提示框
  • android布局教程
  • javascript文档对象
  • jquery图片上传
  • 国家税务总局青海省税务局
  • 纳税人谈感受
  • 江西省税务局拟录用人员公示
  • 南京地税局局长名单
  • 福建电子税务局登录入口
  • 天津国税发票查询真伪查询
  • 小规模纳税人租赁收入增值税税率是多少
  • 牛力扳手怎么用
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设