返回顶部
首页 > 资讯 > 数据库 >MySQL分表自增ID问题的解决方法
  • 341
分享到

MySQL分表自增ID问题的解决方法

2024-04-02 19:04:59 341人浏览 泡泡鱼
摘要

这篇文章主要讲解了“Mysql分表自增ID问题的解决方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql分表自增ID问题的解决方法”吧! 当我们对

这篇文章主要讲解了“Mysql分表自增ID问题的解决方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql分表自增ID问题的解决方法”吧!

当我们对Mysql进行分表操作后,将不能依赖MySQL的自动增量来产生唯一ID了,因为数据已经分散到多个表中。  

应尽量避免使用自增IP来做为主键,为数据库分表操作带来极大的不便。

postgresqloracle、db2数据库中有一个特殊的特性---sequence。 任何时候数据库可以根据当前表中的记录数大小和步长来获取到该表下一条记录数。然而,MySQL是没有这种序列对象的。

可以通过下面的方法来实现sequence特性产生唯一ID:
1. 通过MySQL表生成ID
对于插入也就是insert操作,首先就是获取唯一的id了,就需要一个表来专门创建id,插入一条记录,并获取最后插入的ID。代码如下:

CREATE TABLE `ttlsa_com`.`create_id` ( 
`id` BIGINT( 20 ) NOT NULL AUTO_INCREMENT PRIMARY KEY
) ENGINE = MYISAM

也就是说,当我们需要插入数据的时候,必须由这个表来产生id值,我的PHP代码的方法如下:

<?php 
function get_ai_ID() { 
    $sql = "insert into create_id (id) values('')"; 
    $this->db->query($sql); return $this->db->insertID(); 
} ?>

这种方法效果很好,但是在高并发情况下,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

function get_next_autoincrement_waitlock($timeout = 60){
 $count = $timeout > 0 ? $timeout : 60; while($r->get("serial:lock")){
 $count++;
 sleep(1); if ($count > 10) return false;
 } return true;
}
 
function get_next_autoincrement($timeout = 60){ // first check if we are locked... if (get_next_autoincrement_waitlock($timeout) == false) return 0;
 
 $id = $r->incr("serial"); if ( $id > 1 ) return $id; // if ID == 1, we assume we do not have "serial" key... // first we need to get lock. if ($r->setnx("serial:lock"), 1){
 $r->expire("serial:lock", 60 * 5); // get max(id) from database. $id = select_db_query("select max(id) from user_posts"); // or alternatively: // select id from user_posts order by id desc limit 1 // increase it $id++; // update Redis key $r->set("serial", $id); // release the lock $r->del("serial:lock"); return $id;
 } // can not get lock. return 0;
}
 
$r = new Redis();
$r->connect("127.0.0.1", "6379");
 
$id = get_next_autoincrement(); if ($id){
    $sql = "insert into user_posts(id,user,message)values($id,'$user','$message')" $data = exec_db_query($sql);
}

3. 队列方式

其实这也算是上面的一个解说
使用队列服务,如redis、memcacheq等等,将一定量的ID预分配在一个队列里,每次插入操作,先从队列中获取一个ID,若插入失败的话,将该ID再次添加到队列中,同时监控队列数量,当小于阀值时,自动向队列中添加元素。

这种方式可以有规划的对ID进行分配,还会带来经济效应,比如QQ号码,各种靓号,明码标价。如网站的userid, 允许uid登陆,推出各种靓号,明码标价,对于普通的ID打乱后再随机分配。

<?php class common { private $r;
 
    function construct() {
     $this->__construct();
    } public function __construct(){
     $this->r=new Redis();
     $this->r->connect('127.0.0.1', 6379);
    }
 
    function set_queue_id($ids){ if(is_array($ids) && isset($ids)){ foreach ($ids as $id){
     $this->r->LPUSH('next_autoincrement',$id);
     }
     }
    }
 
    function get_next_autoincrement(){ return $this->r->LPOP('next_autoincrement');
    }
 
}
 
$createid=array(); while(count($createid)<20){
    $num=rand(1000,4000); if(!in_array($num,$createid))
        $createid[]=$num;
}
 
$id=new common();
$id->set_queue_id($createid);
 
var_dump($id->get_next_autoincrement());

监控队列数量,并自动补充队列和取到id但并没有使用

感谢各位的阅读,以上就是“MySQL分表自增ID问题的解决方法”的内容了,经过本文的学习后,相信大家对MySQL分表自增ID问题的解决方法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL分表自增ID问题的解决方法

本文链接: https://lsjlt.com/news/58745.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MySQL分表自增ID问题的解决方法
    这篇文章主要讲解了“MySQL分表自增ID问题的解决方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL分表自增ID问题的解决方法”吧! 当我们对...
    99+
    2024-04-02
  • 如何解决MySQL自增ID用完的问题
    本篇内容介绍了“如何解决MySQL自增ID用完的问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!自增id...
    99+
    2024-04-02
  • mysql id自增冲突问题怎么解决
    解决MySQL ID自增冲突问题有以下几种方法: 使用AUTO_INCREMENT:在创建表的时候,可以设置ID字段为AUTO_...
    99+
    2024-04-09
    mysql
  • mysql自增id超大问题的排查与解决
    引言 小A正在balabala写代码呢,DBA小B突然发来了一条消息,“快看看你的用户特定信息表T,里面的主键,也就是自增id,都到16亿了,这才多久,在这样下去过不了多久主键就要超出范围了,插入就会失败...
    99+
    2024-04-02
  • MySQL自增ID达到上限的解决方法
    MySQL 自增 ID 用完了怎么办?在MySQL中有很多类型的自增ID,每个自增ID都设置了初始值,然后按照一定的步长增加,只要定义了字节长度,那么就会有上限,如果达到上限再次添加,则会报主键冲突错误,解...
    99+
    2024-04-02
  • mysql id从1开始自增 快速解决id不连续的问题
    mysql id从1开始自增 解决id不连续 作为一个强迫症患者,对于表格内某些行删除之后,id不连续这个问题完全无法容忍,一开始使用 TRUNCATE TABLE tablen...
    99+
    2024-04-02
  • MySQL的自增ID(主键) 用完了的解决方法
    在 MySQL 中用很多类型的自增 ID,每个自增 ID 都设置了初始值。一般情况下初始值都是从 0 开始,然后按照一定的步长增加(一般是自增 1)。一般情况下,我们都是用int(11)来作为数据表的自增 ID,在 ...
    99+
    2022-05-10
    MySQL 自增ID MySQL 主键 MySQL 自增ID用完
  • 如何解决Mysql更新自增主键id遇到的问题
    这篇文章主要为大家展示了“如何解决Mysql更新自增主键id遇到的问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何解决Mysql更新自增主键id遇到的问题”这篇文章吧。为什么要更新自增id...
    99+
    2023-06-21
  • mysql设置自增ID的方法
    小编给大家分享一下mysql设置自增ID的方法,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!mysql设置自增ID的方法:执行【CREATE TABLE empautoinc(ID INT &...
    99+
    2024-04-02
  • 解决SQL SERVER 2012自增ID突然断开的问题(ID突然增加1000的)
    最近这两年创建数据库的自增Id列总是出现一个问题,一开始自增正常,都是1、2、3递增,突然就变成1004、1005这样,一直以为程序有问题,后来多次查阅资料才在国外网站上找到问题。 最近这两年创建数据...
    99+
    2018-10-24
    解决SQL SERVER 2012自增ID突然断开的问题(ID突然增加1000的)
  • mysql数据自增ID为2的解决方案
    目录mysql数据自增ID为2问题mysql自增id理解1. 什么是自增id2. 自增id的好处3. 自增id的坏处4. 当自增id用完了怎么办?总结mysql数据自增ID为2问题 查看配置 show variables...
    99+
    2022-12-27
    mysql数据自增ID为2 mysql自增ID mysql自增ID为2
  • mysql设置自增长id的方法
    这篇文章主要介绍mysql设置自增长id的方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!mysql设置自增长id的方法:首先创建好数据库,选择Create Table;然后在设计...
    99+
    2024-04-02
  • Mysql更新自增主键id遇到的问题
    目录为什么要更新自增id问题如何解决本是一个自己知道的问题,还是差点踩坑(差点忘了,还好上线前整理上线点时想起来了),特此记录下来 为什么要更新自增id 我是因为历史业务上的坑,导致...
    99+
    2024-04-02
  • Mysql自增id冲突怎么解决
    Mysql自增id冲突通常是由于插入数据时出现了并发操作导致的。为了解决这个问题,可以采取以下几种方法:1. 使用事务:在插入数据时...
    99+
    2023-10-23
    Mysql
  • Mysql自增id的示例分析
    这篇文章主要为大家展示了“Mysql自增id的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Mysql自增id的示例分析”这篇文章吧。导读:在使用MyS...
    99+
    2024-04-02
  • mysql创建表设置表主键id从1开始自增的解决方案
    目录一.问题描述二.解决方案1.实现步骤2.演示总结一.问题描述 当我们在做项目的时候,创建一张用户表,如何让该表的主键id从0开始自增?网上搜索了很多解决方案,最后发现了一种方法必实现且有效的方案。下面就来介绍实现方法...
    99+
    2023-04-19
    mysql中如何让主键的自增为1 mysql创建自增主键 mysql怎么设置主键
  • mybatis-plus添加数据时id自增问题及解决
    目录mybatis-plus添加数据时id自增问题解决方案插入记录的主键自增赋值机制说明代码说明1、找到执行入口2、看看keyGenerator的执行逻辑3、 跟进逻辑执行4、继续进...
    99+
    2024-04-02
  • 关于MySQL自增ID的一些小问题总结
    下面这几个小问题都是基于 InnoDB 存储引擎的。 1. ID最大的记录删除后,新插入的记录ID是什么 例如当前表中有ID为1,2,3三条记录,把3删除,新插入记录的ID从哪儿开始? 答案: 从4开始。...
    99+
    2024-04-02
  • 解决mysql的int型主键自增问题
    引入 我们在使用mysql数据库时,习惯使用int型作为主键,并设置为自增,这既能够保证唯一,使用起来又很方便,但int型的长度是有限的,如果超过长度怎么办呢? 暴露问题 我们先创建...
    99+
    2024-04-02
  • MySQL自增ID用完了如何解决
    本篇文章为大家展示了MySQL自增ID用完了如何解决,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。首先,创建一个最简单的表,只包含一个自增id,并插入一条数据。cr...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作