位置: 编程技术 - 正文

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

  • 施工合同的印花税需要合同双方都缴纳吗?
  • 出借包装物收取的押金
  • 投资性房地产出售的会计处理
  • 固定资产直接计入成本的规定
  • 年报资产总额是期末余额吗
  • 环境保护税属于什么税种
  • 金蝶财务软件固定资产模块固定资产调拨
  • 煤炭企业会计制度
  • 厂房无偿租赁合同
  • 土地使用税的免税规定有哪些
  • 长期待摊费用进项税可以一次性抵扣吗?
  • 研发费用加计扣除留存备查资料
  • 摊销土地使用权和专利权会计分录怎么写
  • 出售车辆需要缴纳哪些税
  • 个人销售货物缴纳增值税吗
  • 收购农产品销售会计分录怎么写
  • 个人购买房屋的税
  • 退股支付的现金流量表怎么填
  • 收到运费发票是进项还是销项
  • 预缴企业所得税是含税还是不含税
  • 库存周转天数计算实例
  • 到期一次还本付息的利息怎么算
  • 判决公告费应计入哪个科目?
  • 解除劳动关系补偿标准
  • 宝塔linux面板怎么安装
  • 职工福利费的计提标准
  • 筹建期的开办费需要归集后才能一次性扣除吗
  • win10待机屏幕图片设置
  • 通过mac地址查找ip的协议
  • vue数据实时更新
  • 储金会是干什么的
  • 安徽4岁男孩户口已解决
  • vue 使用js
  • php xml转数组
  • uniapp components
  • 软件是无形的,可见的物理实体
  • 无法将node项识别为
  • 此战成硕,我成功上岸西南交通大学了~~~
  • 第十届蓝桥杯大赛个人赛省赛结果
  • js面试必问
  • laravel 实例
  • 企业资产损失税前扣除管理办法最新
  • 产品检测费可以放入研发费用吗
  • 油票抵税的顺序步骤是什么
  • 上个月的票这个月作废后报增值税需不需要交费?
  • 制造费用月末一般有余额吗
  • python并发和并行
  • 织梦自定义模型调用
  • 季度所得税怎么算
  • 小规模简易征收最新政策2020
  • 年底了,你们公司年会干点啥都?
  • 公司注销持股1%的股东需要他签字吗
  • 应收账款余额在借方还是贷方
  • 一般纳税人收取停车费的税率
  • 事业单位会计的特点
  • 退休人员基本养老金包括哪些
  • 应收未收的款项如何会计处理
  • 固定资产折旧方法不考虑净残值
  • u极速u盘启动官网
  • 文件历史版本功能
  • windows2003怎么样
  • windows server 2008 r2安装教程
  • mac如何设置启动系统
  • centos sudoers
  • 本地硬盘满了怎么办
  • 电脑开机蓝屏怎么解决xp系统
  • 安装yum的命令
  • WIN7系统中WQRD超链接打不开怎么办
  • cocos2dx怎么用啊
  • 怎样提升android的版本为最新版本?
  • jQuery ajax 当async为false时解决同步操作失败的问题
  • unity打包安卓apk
  • unity toggle切换状态
  • js的ajax请求写法
  • javascript每隔一秒调用函数
  • 房产的原值以什么为准
  • 个人所得税自行纳税申报表(A表)
  • 一般纳税人收到普通发票怎么做分录
  • 贵州网上办税服务厅登录
  • 深圳市百旺信投资有限责任公司
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设