位置: 编程技术 - 正文

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 文件系统
  • 编写一个php程序,展示双引号和单引号的区别
  • 投资性房地产成本法转公允价值法
  • 大学生web前端期刊有哪些
  • php类型约束用法有哪些
  • 没有计提坏账准备的应收帐款坏帐帐务处理
  • audo命令
  • java transactional
  • 固定资产清理的借贷方向表示什么
  • vue如何实现路由跳转缓存
  • python2.7 协程
  • 织梦专题页模板
  • 材料采购与原材料账户核算内容有何差别
  • 审计外聘人员支付标准
  • mysql 锁详解
  • 建筑工程租赁费属于什么费用
  • 一般纳税人增值税结转账务处理
  • 公司涉及研发房怎么办
  • 报销餐费增值税进项税计入什么科目
  • 固定资产报废后怎么处理
  • 母猪生小猪会计分录
  • 长期待摊费用的摊销期限应该是
  • 进项税额允许抵扣分录
  • 其他应付款的核算范围包括应付短期租赁
  • aspnet数据库访问
  • mysql die
  • mysql的安全级别
  • mysql添加外键约束的sql语句
  • ubuntu xenial
  • 删除windows.old文件夹后 桌面没有了
  • win8.1使用技巧大全
  • windows 10 build 9834
  • Centos7 中 Node.js安装简单方法
  • 最简单的游戏开发工具
  • android开发最全教程
  • linuxparted命令
  • python matplotlab
  • cls方法可以清除
  • 批处理计数
  • javascript可以制作哪些游戏?
  • shell脚本wc
  • jquery动态
  • python随机发红包代码
  • javascript入门教学
  • jquery技巧
  • 吉林省地税局电话号码
  • 请问3.3排量的汽车
  • 退回的汽车保险入什么科目
  • 水费不用交吗
  • ipo上市要注意什么
  • 图书行业税率多少
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设