草庐IT

MYSQL auto_increment_增量

coder 2023-10-05 原文

我想在单个 mysql 数据库中自动增加两个不同的表,第一个增加 1 的倍数,另一个增加 5 是否可以使用 auto_increment 功能,因为我似乎只能全局设置 auto_increment_increment。

如果 auto_increment_increment 不是一个选项,那么复制它的最佳方法是什么

最佳答案

更新版本:只使用了一个 id 字段。这很可能不是原子的,所以如果您需要并发,请在事务内部使用:

http://sqlfiddle.com/#!2/a4ed8/1

CREATE TABLE IF NOT EXISTS person (
   id  INT NOT NULL AUTO_INCREMENT,
   PRIMARY KEY ( id )
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1;

CREATE TRIGGER insert_kangaroo_id BEFORE INSERT ON person FOR EACH ROW BEGIN
  DECLARE newid INT;

  SET newid = (SELECT AUTO_INCREMENT
               FROM information_schema.TABLES
               WHERE TABLE_SCHEMA = DATABASE()
               AND TABLE_NAME = 'person'
              );

  IF NEW.id AND NEW.id >= newid THEN
    SET newid = NEW.id;
  END IF;

  SET NEW.id = 5 * CEILING( newid / 5 );
END;

旧的、不起作用的“解决方案”(插入前触发器看不到当前的自动增量值):

http://sqlfiddle.com/#!2/f4f9a/1

CREATE TABLE IF NOT EXISTS person (
   secretid  INT NOT NULL AUTO_INCREMENT,
   id        INT NOT NULL,
   PRIMARY KEY ( secretid )
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1;

CREATE TRIGGER update_kangaroo_id BEFORE UPDATE ON person FOR EACH ROW BEGIN
  SET NEW.id = NEW.secretid * 5;
END;

CREATE TRIGGER insert_kangaroo_id BEFORE INSERT ON person FOR EACH ROW BEGIN
  SET NEW.id = NEW.secretid * 5; -- NEW.secretid is empty = unusuable!
END;

关于MYSQL auto_increment_增量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11308438/

有关MYSQL auto_increment_增量的更多相关文章

  1. ruby-on-rails - 有没有一种工具可以在编码时自动保存对文件的增量更改? - 2

    我最喜欢的Google文档功能之一是它会在我工作时不断自动保存我的文档版本。这意味着即使我在进行关键更改之前忘记在某个点进行保存,也很有可能会自动创建一个保存点。至少,我可以将文档恢复到错误更改之前的状态,并从该点继续工作。对于在MacOS(或UNIX)上运行的Ruby编码器,是否有具有等效功能的工具?例如,一个工具会每隔几分钟自动将Gitcheckin我的本地存储库以获取我正在处理的文件。也许我有点偏执,但这点小保险可以让我在日常工作中安心。 最佳答案 虚拟机有些人可能讨厌我对此的回应,但我在编码时经常使用VIM,它具有自动保存功

  2. ruby-on-rails - 用一系列时间增量填充选择,加上其他选项 - 2

    使用RubyonRails,我使用给定的增量(例如每30分钟)用时间填充“选择”。目前我正在YAML文件中写出所有的可能性,但我觉得有一种更巧妙的方法。我想我想提供一个开始时间、一个结束时间、一个增量,并且目前只提供一个名为“关闭”的选项(想想“business_hours”)。所以,我的选择可能会显示:'Closed'5:00am5:30am6:00am...[allthewayto]...11:30pm谁能想出更好的方法,或者只是将它们全部“拼写”出来的最佳方法? 最佳答案 此答案基于@emh的答案。defcreate_hour

  3. Ruby 增量 (+=) 引发错误 undefined method '+' for nil :NilClass - 2

    以下代码导致了我的问题:classFoodefinitialize(n=0)@n=nendattr_accessor:ndefincn+=1endend调用Foo.new.inc引发NoMethodError:undefinedmethod'+'fornil:NilClass调用Foo.new.n返回0为什么Foo.new.inc会引发错误?我可以毫无问题地执行Foo.new.n+=1。 最佳答案 tldr;某种形式的self.n=x必须始终用于分配给setter。考虑n+=x扩展为n=n+x其中n被绑定(bind)为局部变量因为它

  4. ruby-on-rails - 在 Ruby on Rails 中增量构建任意 URL - 2

    我有一个字符串形式的URL。向其中添加一些参数最简洁的方法是什么?例如base='http://example.com'uri1=some_magical_method(base,:p1=>'v1')#=>http://example.com/?p1=v1uri2=some_magical_method(uri1,:p2=>'v2')#=>http://example.com/?p1=v1&p2=v2uri3=some_magical_method(uri2,:p3=>nil)#=>http://example.com/?p1=v1&p2=v21)在Ruby中?2)在Rails中?

  5. DolphinScheduler 调度 DataX 实现 MySQL To ElasticSearch 增量数据同步实践 - 2

    数据同步的方式数据同步的2大方式基于SQL查询的CDC(ChangeDataCapture):离线调度查询作业,批处理。把一张表同步到其他系统,每次通过查询去获取表中最新的数据。也就是我们说的基于SQL查询抽取;无法保障数据一致性,查的过程中有可能数据已经发生了多次变更;不保障实时性,基于离线调度存在天然的延迟;工具软件以Kettle(ApacheHop最新版)、DataX为代表,需要结合任务调度系统使用。基于日志的CDC:实时消费日志,流处理,例如MySQL的binlog日志完整记录了数据库中的变更,可以把binlog文件当作流的数据源;保障数据一致性,因为binlog文件包含了所有历史变更

  6. ruby-on-rails - .增量 vs += 1 - 2

    我有一个图片模型,其中包含一个用于查看次数(整数)的变量。每次有人查看Picture对象时,查看计数都会增加+1。在完成这件事时,有什么区别@picture.view_count+=1@picture.save和@picture.increment(:view_count,1)另外,如果我使用增量,是否需要.save? 最佳答案 increment的来源如下,如果nil将属性初始化为零,并添加传递的值(默认为1),它不保存,所以.save仍然是必要的。defincrement(attribute,by=1)self[attribut

  7. ruby-on-rails - ruby 中的增量变量 - 2

    这个问题在这里已经有了答案:Whydoesn'tRubysupporti++ori--​(increment/decrementoperators)?(9个回答)关闭9年前。在Java中,i++会把i加1。我可以用Ruby做什么?肯定有比i=i+1更好的方法吗?

  8. Ruby:如何迭代一个范围,但以设定的增量进行? - 2

    所以我像这样遍历一个范围:(1..100).eachdo|n|#n=1#n=2#n=3#n=4#n=5end但我想做的是以10为单位进行迭代。因此,不是将n增加1,下一个n实际上是10,然后是20、30,等等。 最佳答案 参见http://ruby-doc.org/core/classes/Range.html#M000695获取完整的API。基本上您使用step()方法。例如:(10..100).step(10)do|n|#n=10#n=20#n=30#...end 关于Ruby:如何

  9. ruby - Ruby 中没有增量运算符 (++)? - 2

    这个问题在这里已经有了答案:关闭12年前。PossibleDuplicate:Whydoesn'tRubysupporti++ori—forfixnum?为什么Ruby中没有自增运算符?例如i++++i++运算符是否用于其他用途?这有真正的原因吗?

  10. javascript - 以两个为增量解构数组 - 2

    假设我有一个这样的数组:letarr=[1,2,3,4,5,6,"a"]我怎样才能将它解构为以两个为增量的单个变量?那么letone=[1,2],lettwo=[3,4]等等?我知道您可以像这样使用单个变量来解构数组:letone,two,three;[one,two,three]=arr但是以两个为增量进行,这可能吗? 最佳答案 另一种方法是通过ES6generatorfunction:letarr=[1,2,3,4,5,6,'a']function*batch(arr,n=2){letindex=0while(index或者更通

随机推荐