位置: 编程技术 - 正文

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

  • 自然人报税系统怎么进入单位报税系统
  • 技术服务费属于哪个商品编码
  • 以前年度损益调整结转到哪里
  • 土地使用权分割转让依据
  • 工会经费和职工教育经费比例
  • 固定资产的建造成本包括
  • 房产税逾期未申报罚款多少
  • 混搭销售的企业有哪些
  • 营改增对建筑业的影响有哪些
  • 农业企业土地租金会计分录
  • 企业收到的政府补贴,怎么入账
  • 什么是企业所得税收入
  • 公司发给员工的奖金要交税吗
  • 集体土地上的不动产证已经能查询为何房产证拿不到
  • 前三季度盈利第四季度亏损 所得税记账
  • 纳税人必须关注的10个涉税风险点
  • 建筑安装业跨省经营管理税务通知
  • 政府专项补助如何处理
  • 直接成本和间接成本差异
  • 增值税申报表能更正申报吗
  • 小规模自开专票税率是1%还是3%
  • 订阅报纸属于会计科目吗
  • windows10如何开启wifi
  • 香港企业股东分红税
  • 怎样启动powerpoint
  • 政府收储土地补偿款账务处理
  • 个体工商税务登记需要费用
  • linux模块的概念
  • 企业所得税分析方法
  • php中link什么意思
  • 个人独资企业怎么做账
  • PHP:imagecreatefromgd2()的用法_GD库图像处理函数
  • 外管证预缴税费怎么算
  • 已提足折旧固定资产改建支出 所得税怎么计算
  • vue好不好学
  • 融资租入固定资产
  • 贴现资产卖断会怎么样
  • 小规模纳税人开票额度
  • 财务报表季报应付职工薪酬是指三个月工资累计还是
  • 单位收的房租可以发工资吗
  • python中排序
  • db2原理
  • 给子公司注资怎么做账
  • 借款可以抵扣企业所得税
  • 珠宝行业会计核算流程
  • 商业承兑汇票托收什么意思
  • 用于出口的进项发票怎么做账
  • 物业公司劳务外包
  • 高新企业研发收入占总收入比例怎么算
  • 植物售卖
  • 增值税普通发票有什么用
  • 发行价格另支付发行费用
  • 印花税的征税对象有哪些
  • 售楼部装修费计入什么科目
  • 如何操作开具红字发票
  • 等额年金终值系数与偿债资金系数互为倒数
  • 242104 税控盘
  • 在长期股权投资中,如何理解控制、重大影响?
  • 银行回单和发票哪个粘贴到上面
  • 净资产增长率增长说明什么
  • 企业明细是什么
  • mysql行锁的作用
  • win7系统的笔记本电脑有哪些
  • freebsd怎么样
  • centos 查看文件夹
  • win10应用商店下载不了
  • cocos2d
  • 解决Extjs 4 Panel作为Window组件的子组件时出现双重边框问题
  • supervisor producer
  • 【ExpandableListView】ExpandableListView互斥展开效果
  • 如何删除命令
  • jqgrid api中文手册
  • 使用jquery实现的项目
  • js构造器constructor
  • 自治区地方税务局于立民简介
  • 宁波税务总局官网
  • 纳税服务主要职责
  • 全国税务系统全面从严治党工作会议2023年
  • 深圳企业公积金更改代扣银行
  • 国税局和地税局有什么区别
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设