- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
注意:我是数据库和 PHP 新手
我有一个order
列,设置为自动增量
和唯一
。
在我的 PHP 脚本中,我使用 AJAX 来获取新数据,但问题是,order
会跳过数字并且明显更高,因此迫使我在以下情况下手动更新数字:数据被插入。在这种情况下,我最终会将 782
更改为 38
。
$SQL = "INSERT IGNORE INTO `read`(`title`,`url`) VALUES\n ".implode( "\n,",array_reverse( $sql_values ) );
如何让它增加+1?
最佳答案
如果 INSERT 失败,MySQL 5.1 及更高版本中的默认 auto_increment 行为将“丢失”自动增量值。也就是说,它每次增加 1,但如果 INSERT 失败则不会撤消增量。丢失约 750 个值的情况并不常见,但并非不可能(我咨询过一个网站,该网站每次成功插入都会跳过 1500 个值)。
您可以更改innodb_autoinc_lock_mode=0
以使用MySQL 5.0行为并避免在某些情况下丢失值。请参阅http://dev.mysql.com/doc/refman/5.1/en/innodb-auto-increment-handling.html了解更多详情。
另一件事要检查的是 auto_increment_increment
配置变量的值。默认情况下为 1,但您可能已更改此值。同样,将其设置为高于 1 或 2 的情况很少见,但也是可能的。
我同意其他评论者的观点,autoinc 列旨在是唯一的,但不一定是连续的。您可能不应该太担心它,除非您将 autoinc 值提高得如此之快以至于您可能会超出 INT 的范围(这已经发生在我身上)。
<小时/>How exactly did you fix it skipping 1500 for ever insert?
INSERT 失败的原因是另一列带有 UNIQUE 约束,并且 INSERT 试图在该列中插入重复值。请阅读我链接到的手册页,详细了解为什么这很重要。
修复方法是在尝试 INSERT 之前先执行 SELECT 来检查该值是否存在。这违背了常识,即仅尝试插入并处理任何重复的键异常。但在这种情况下,失败的 INSERT 的副作用导致 auto-inc 值丢失。首先执行 SELECT 消除了几乎所有此类异常。
但是您还必须处理可能的异常,即使您先选择。您仍然存在竞争条件。
You're right! innodb_autoinc_lock_mode=0 worked like a charm.
就您而言,我想知道为什么这么多插入失败。我怀疑,像许多 SQL 开发人员一样,在 AJAX 处理程序中执行 INSERT 后,您不会检查成功状态,因此您永远不知道其中有很多都失败了。
他们可能仍然失败,你只是没有失去自动添加 ID 作为副作用。您应该真正诊断为什么会发生如此多的失败。您可能会生成不完整的数据,或者运行超出必要数量的事务。
关于php - 自动递增跳过数字?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41414336/
我正在实现一个算法,当用户输入字符串时,字符串中的每个字符(如果是字母表)都应该增加给定的值(这里是旋转器)。我正在玩这个代码 2 小时,但无法弄清楚为什么当我按值旋转器递增时,它会按 rotator
我有 1.0.5。我怎样才能增加到 1.0.6? 试过了,但是不行。 echo 1.0.5 0.0.1 | awk '{sum=$1+$2; printf"%0.2f\n", sum }' 最佳答案
这个问题在这里已经有了答案: Behaviour of increment and decrement operators in Python (11 个回答) Why are there no ++
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎偏离主题,因为它缺乏足够的信息来诊断问题。 更详细地描述您的问题或 include a mini
我正在尝试温习我的 C,我有以下代码,当我使用 i 偏移量但不使用 Hold++ 时,它可以工作,我不明白为什么我认为他们做了同样的事情?这是我无法开始工作的版本: char* reversestri
我需要增加/减少 PostgreSQL 数据库中的计时。 下面是包含列类型为"timestamp without time zone" 的表的输出 如果时间超过 24 小时,我也需要更改日期。请协助
我有一个名为 temp_rfm 的表,其中 col1 实际上是客户 ID(我有一个非法的联盟混合问题)和 calc_date 是增加月份的开始。 SELECT * FROM temp_rfm ; co
我目前正在处理我的应用程序的首选项,我必须设置一个角度。默认值约为 30°,用户应该能够调整此角度以使其最适合。 我不只是制作一个普通的 EditTextPreference,而是希望它可以像在其他应
这个问题已经有答案了: Increment a number by prefix and postfix operator (1 个回答) 已关闭去年。 我正在努力理解 Javascript 增量运算
我使用下面的 javascript 递归地重新加载一个目标 DIV,其 id="outPut",将参数传递给 getData.php 时执行数据查询的结果>。问题是 fadeTo 会淡化每次迭代调用返
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Jquery Draggable + Bring to Front 我有一个网站,用户可以在其中打开多个聊天
我必须定义一个函数,其中: Starting with a positive integer original, keep multiplying original by n and calculat
我正在我的应用程序中记录一些统计数据。其中一项统计数据是 BigDataStructure 的大小。我有两个选择: 创建一个计数器并递增/每次递减计数器有一个添加/删除大数据结构。 每次添加/删除从
在下面的 Java 示例程序中,我得到了无限循环,我不明白为什么: public class Time { public static int next(int v) { re
我从 C#/WPF 添加了一个意外的行为 private void ButtonUp_Click(object sender, RoutedEventArgs e) {
我想在 Python 2.7 中增加用户提供的字符串的最后一位数字。 我可以这样替换第一个数字: def increment_hostname(name): try: numb
我正在用蛮力搜索具有某些属性的 float (sin(a)^2+cos(a)^2-1 的小舍入误差)。因此,我想通过递增尾数来遍历给定 float 的邻域。 在 C 中是否有一种简单的方法可以做到这一
C 标准将 _Bool 定义为包含 0 或 1 的无符号类型。如果 _Bool 类型的值 1 递增,据我所知,有两个选项: 该值在 1 到 0 之间环绕 该值增加到 2,它是非零值,因此在转换回 _B
我有一个 INI 文件,其中存储了一些用于设置的整数。部分名称存储如下: [ColorScheme_2] name=Dark Purple Gradient BackgroundColor=224 B
我的应用程序中有这个方法: - (void)initializeTimer{ self.myTimer = [NSTimer scheduledTimerWithTimeInterval:th
我是一名优秀的程序员,十分优秀!