位置: 编程技术 - 正文

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

  • 土地增值税要计增值税吗
  • 支付的运输费用计入什么科目
  • 固定资产出售净残值怎么处理
  • 劳务报酬需要补税吗
  • 保险金扣税吗
  • 现金折扣是否可抵税
  • 2020年减免水利基金会计分录
  • 应交税金减免税金需要结转吗
  • 现金存入公司账户风险大吗安全吗
  • 营改增后挂靠开票作收入吗?
  • 土地配套费如何缴纳
  • 补缴税款会计处理
  • 2018年房地产行业分析
  • 定期定额个体工商户个人所得税
  • 员工激励该怎么表达
  • 客户忠诚度的表现行为有哪些
  • 建筑公司材料费属于什么科目
  • 不动产公告期
  • 净资产怎么算的 视频
  • 企业没有进项票只有成本票
  • 开发票有时间限制吗?
  • 企业所得税法中规定的收入总额包括
  • 计提房租费
  • ajax调用php函数
  • 教学用品列入什么费用
  • 如何在局域网内发布网页
  • element-plus vue
  • 手机短信是哪一年开始的
  • 利息补偿金怎么算
  • PHP:mcrypt_module_close()的用法_Mcrypt函数
  • 最小的触屏手机有哪些
  • 佛法戒律论
  • yolov5 workers
  • anaconda的虚拟环境的作用
  • laravel访问路由方式
  • 公户发工资必须是员工账号必须是公户开户行吗
  • vue自定义dialog
  • 残差网络中的残差指的是什么
  • 小企业发票打印流程
  • 费用科目在贷方表示
  • 小企业固定资产折旧方法
  • 固定资产记到什么账本
  • 大陆工作的香港人可以开基金账户吗
  • 印花税补交会怎样
  • 印花税申报的流程有哪些
  • 土地使用发票
  • 专项应付款 会计分录
  • 实收资本核算内容是什么
  • 劳务公司可以用工资表做成本
  • 营改增后个人所得税计税依据实例
  • 现金返利的会计分录
  • 所得税需要转本吗
  • 以前年度少计提的工资怎么处理
  • 培训费开票属于劳务费吗
  • 长期股权投资哪一章
  • 自产委托加工的货物用于非增值税应税项目
  • 股东是否实缴出资的举证责任
  • sqlserver向表中添加数据用什么命令
  • Mysql 报Row size too large 65535 的原因及解决方法
  • myeclipse中连接数据库的地方在哪
  • win10 mysql 5.6.35 winx64免安装版配置教程
  • win8.1还原系统
  • fedora安装中文语言包
  • windows 10激活不了
  • SymSPort.exe - SymSPort是什么进程 有何作用
  • css中的单位主要有哪些
  • 如何优化营商环境
  • unity3d ik
  • Linux删除大量文件
  • 如何让批处理文件运行不显示
  • 完美解决怠速抖动加油就平稳
  • vue2.0与bootstrap3实现列表分页效果
  • javascript要学到什么程度
  • javascript面向对象精要pdf
  • 关于明确干部挂职工作期间有关待遇的
  • 国家税务总局惠州仲恺高新技术产业开发区税务局
  • 车辆购置税是财行税吗
  • 应纳税所得额怎么求公式
  • 三证一码是什么
  • 同比减少怎么计算出来
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设