位置: 编程技术 - 正文

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

  • 福利费进项税额转出会计分录账务处理
  • 税务ukey电子发票二维码用什么扫码
  • 个人所得税手续费返还要交企业所得税吗
  • 收不回来的装修钱怎么办
  • 钢材贸易公司是做什么的
  • 股票股利的资金来源
  • 申请电子发票需要交钱吗
  • 退回投资款怎么做账
  • 怎么调开票金额
  • 采购是进项还是销项
  • 辅导期一般纳税人管理办法
  • 厂房怎么计提折旧费
  • 参与工会职工应享受哪些福利待遇
  • 进项抵欠税相关政策
  • 新公司核税需要什么资料
  • 企业如何申请科研项目
  • 变更银行手机号需要去银行吗
  • 行政会计账务处理
  • 建筑业购进苗木进项抵税计算公式是什么
  • 税率为0的增值税发票能抵扣吗
  • 免税发票可以入账吗
  • 申报营业额怎么填
  • 统一社会信用代码证
  • 无租使用房产协议
  • 海关增值税当月可以抵扣吗
  • 去年进项税没有抵扣了
  • 网吧登录qq安全吗
  • 有什么好方法可以让小孩子少吃糖
  • PHP:xml_set_default_handler()的用法_XML解析器函数
  • Mac怎么更改默认打开方式
  • Proxmox ve(PVE) 显示CPU和硬盘温度、UPS信息
  • php字符串变量
  • 公司和个人分别交税一部分吗
  • win11电脑怎么重置
  • 电力安装公司需要什么资质证书
  • php是面向对象编程吗
  • 增值税进项发票丢失最新处理办法
  • php语言采用什么方式执行
  • php教程从入门到精通
  • 新的企业所得税
  • 房产自用改为出租如何申报房产税
  • 认缴制对实务操作的可能影响有哪些?
  • 合同印花税可以年底报一次
  • 未开票要交增值税吗
  • 物业公司属于生活性服务业吗
  • protobuf 文档
  • 纳税申报的流程如何?面试怎么说
  • sql里面union 和union all区别
  • MySQL导入导出命令
  • 借款人和还款人不一致,收据打给谁
  • 个人转让房产税率
  • 大货车怎样申请报废
  • 未达起征点怎么填
  • 安防工程注意事项有哪些
  • 小规模纳税人和一般纳税人的界定标准
  • 支出记账凭证单手写
  • 存货周转次数下降的原因
  • 预付账款的会计处理
  • 公司不按照劳动法给工资怎么办
  • 展览展示服务费计入什么科目
  • 企业成立前期的重点工作
  • MySQL中truncate误操作后的数据恢复案例
  • bash.exe
  • 使用windows防火墙禁止软件联网
  • windows7安装过程中出错
  • Win10 Mobile RS2预览版14915上手视频评测
  • 升级win10系统后电脑变卡处理方法
  • 极限竞速中心应用程序
  • win10系统开机蓝屏,重启就好
  • 微软发布ChatGPT功能
  • 耳朵前皮下有个小软包
  • 完美解决mac环境异常
  • jquery cookie存取
  • android:Background线程池和UiThread线程池
  • 安卓消息处理机制
  • 湖北省税务系统欠税管理工作指南
  • 国家税务局发票查询
  • 如何办理清税证书
  • 税务局发票邮寄回来怎么读入?
  • 广西汽车下乡补贴申请攻略?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设