位置: 编程技术 - 正文

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

  • 出口退税超期未缴税
  • 家里财产分割
  • 生产成本怎么核实
  • 政府会计固定资产盘亏的账务处理
  • 发票税率金额如何得出
  • 企业会计准则和新会计准则的区别
  • 增值税计入当期损益吗?
  • 金税三期国地税合并
  • 售后维修费怎么开票
  • 交易性金融资产入账价值怎么计算
  • 营改增后场地租赁税率
  • 差额纳税销项税额抵减
  • 跨季度的发票怎么冲销
  • 商标是按年交费的吗
  • 融资租赁租金及利息计算
  • 工会经费怎么做账务处理
  • 家具上的木蜡油味去除
  • 跨月发票冲红账怎么做
  • 按揭的车可以只买交强险吗
  • 固定资产少计提了怎么办
  • 资本的不同形态
  • 雨林木风 u盘
  • php常用的技术栈
  • 其他综合收益是什么意思
  • 税费缴纳比例
  • PHP简单实现HTTP和HTTPS跨域共享session解决办法
  • 其他业务收入产品包括
  • 跨年租赁费如何处理
  • 企业所得税税金及附加包括
  • 审计项目种类
  • 民营企业的工业项目建设-经营-转让是什么模式
  • 财务的几张报表
  • is-l命令
  • php 电子签名
  • 简单的画
  • 如何让网站优化成功
  • 无效发票进项税额抵扣
  • python中myqr的用法
  • php网站根目录
  • dedecms插件
  • 工程结算如何做会计分录
  • 三方协议是什么意思?
  • 一联发票和二联发票
  • 金蝶k3如何设置现金流量表取数公式
  • 什么样的企业才算大企业
  • 关于sqlserver数据库服务器登录账户的说法错误的是
  • db2 -968
  • 劳务费计入工资薪金总额吗
  • 劳务费发票是个人的吗
  • 本期销项税额怎么算
  • 安家费有税吗
  • 折旧方法计算公式
  • 用于捐赠的会计处理
  • 单位车辆折旧费可以税前扣除吗
  • 建筑企业包工包料业务的发票开具和涉税处理
  • 小规模纳税人可以抵税吗
  • 年终结账账务处理
  • 如何填写记账凭证视频
  • 请创建一个die类
  • vnc远程桌面linux
  • linux中使用fdisk命令进行硬盘分区
  • shell中awk命令
  • centos设置双网卡
  • win10系统忘记电脑密码
  • win10非正常关机系统修复
  • Cocos2d之CCScene
  • node.js开发指南
  • android属性大全
  • perl脚本调试方法
  • unity3d官方
  • jquery使用css
  • Firefox window.close()的使用注意事项
  • 面向对象的java语言
  • jquery.js插件
  • python3 functools
  • 怎么打印纳税申报清单
  • 湖南低保查询网上查询
  • 发票汇总表怎么计算
  • 处级工作调动用什么手续
  • 没有代理记账资质的公司从事代理记账业务
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设