位置: 编程技术 - 正文

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 wget命令详解
  • win10家庭最新版
  • 佣金代扣代缴增值税需要缴纳附加税吗
  • 电脑上的五角星是什么意思
  • 补缴增值税和滞纳税区别
  • uniapp实战视频教程
  • js在web前端中的作用
  • php readfile
  • 对其他公司的建议
  • 对方开过来的专票丢了怎么办
  • 特殊行业需要缴什么税
  • vue中el-dialog
  • 现金流量表结构分析
  • php提示框
  • 自然人税收管理系统扣缴客户端app
  • js中的变量
  • php curlfile
  • repo命令详解
  • 如何在国家税务局增值税纳税申报
  • 收到承兑汇票怎么操作
  • 合作社计提工资
  • 销售商品的折扣
  • 企业收到工程款会计分录
  • 帝国cms手机版制作
  • dedecms进入数据库
  • 贷款呆账准备金
  • 信息采集是哪个部门负责
  • 客户多付的货款 不用退回 进营业外收入吗
  • 购进国内交通运输产品
  • 收到材料发票怎么写摘要
  • 长期投资损失
  • 公司代扣代缴社保什么意思
  • 已认证的发票开具红字发票账务处理?
  • 同一张发票报销两次会被发现吗
  • 公司报销发票需要查验真假吗
  • 万达对赌协议是什么
  • 普票丢失可以以照片入账么
  • 投资收益科目的借贷
  • 冲减坏账准备的金额怎么计算
  • 访问和更改关系的区别
  • microsoft window vista
  • centos sudoers
  • windows xp 开机
  • centos7自签名证书
  • 如何删除双系统中的linux系统
  • win7游戏打开没反应
  • windows 8.1 (multiple editions)
  • 网站出现问题怎么办
  • 删除rpm安装包
  • 只有一行的矩阵的逆矩阵
  • nodejs与springboot结合
  • xcopy /i
  • windows配额
  • android图片库
  • jquery keydown
  • 如何用jquery
  • 银行端查询缴税凭证怎么打印
  • 贵州省地方税务局税源管理平台(二次)招标合同公告
  • 成品油和非成品油的税务知识
  • 河南政务服务网官网
  • 安徽省建筑施工企业排名
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设