位置: 编程技术 - 正文

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) 错误的解决办法

  • 组成计税价应该是含税价还是不含税价?
  • 工资延期发放最多不能超过多少天
  • 政府补贴的账务属于哪个科目
  • 什么是明细分类账簿
  • 商会费用会计分录
  • 出纳发票不见了可以用微信转账记录记账吗
  • 暂估成本没有发票
  • 应交增值税销项税额借贷方向
  • 开具了红字发票信息表的税额需要转出吗
  • 计算应交消费税需要扣除代收代缴消费税吗
  • 混凝土委托加工税率
  • 参与工会职工应享受哪些福利待遇
  • 公司房租发票是专票还是普票
  • 诉讼财产保全保险费计算
  • 驾校挂靠车辆账务处理?
  • 招待住宿费计入什么科目
  • 一般纳税人增值税可以抵扣吗
  • 购入汽车
  • 预缴增值税税款网上申报操作流程
  • 预计退货会计英语
  • 酒店业小规模纳税人可以享受2023年应纳税额抵减政策吗
  • 建筑企业差额征收
  • 有了营业执照就可以买社保了吗
  • 资源税征收管理纳税期限
  • 减免税款余额方法有哪些
  • 发了工资了
  • 发票密码区出来了一点
  • 发票已勾选未确认
  • 支票收款
  • 在建工程暂估转固定资产
  • windows10如何切屏
  • 企业拆迁 补偿
  • 会计分录中结转成本
  • npm sill idealTree buildDeps 安装踩坑指南(详细版)
  • 商标转让过程中公司转让
  • Linux系统中Squid代理服务器配置全过程解析
  • PHP:session_write_close()的用法_Session函数
  • 查看chrome浏览器内核版本
  • PHP:mcrypt_enc_get_algorithms_name()的用法_Mcrypt函数
  • vue项目难点及解决方法
  • 制造业企业预提短期借款利息
  • 勃朗峰高度
  • 工程物资已到发票怎么开
  • 关于laravel应用中的各个目录的作用,说法错误的是
  • vue2路由跳转页面不刷新问题
  • 股东以原材料出资
  • 申请专利费用计入哪个科目
  • 强大的图片预览软件
  • 金蝶软件做帐流程
  • 员工报销医药费的会计分录
  • 没有什么盈利的公司应该进吗
  • 销售精装修房如何做账
  • 多提的增值税该怎么做账
  • 费用的分摊要注意什么
  • mongodb如何备份
  • 系统带我玩隐形守护者 小说
  • 代销商品怎么开票
  • 进项税和销项税怎么理解
  • 税前利息为什么这么高
  • 业务招待费算期间费用吗
  • 季度平均人数怎么算出来的
  • 施工单位上报
  • 资产减值损失是借增贷减吗
  • 年初建账的期初余额
  • ubuntu无法进入系统出现uid121
  • linux find -a
  • centos etc
  • win8.1系统安装教程
  • oeloader.exe - oeloader是什么进程 有什么用
  • win1020h2版本是正式版吗
  • libproj.so
  • 常用的git操作
  • 零磁道的重要性
  • scp命令详解(全)
  • js每天的定时任务
  • linux查看shell脚本内容
  • javascript例题
  • 无锡地铁时速多少公里
  • 供给决定需求,需求影响供给
  • 企业租入房子用交税吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设