自动递增 - 每年自动重置

sbr*_*bot 3 mysql innodb auto-increment

MySQL/InnoDB

就我而言,我的收据应按年计算;1/2015、2/2015 ... 556/2015 等等。明年来的时候,柜台应该重新从1开始,收据应该计算为1/2016,2/2016 ...

如何定义将每年重置的 auto_increment 字段?

RCID | RCNO | RCYEAR | ...
=====+======+========+====
 200 |    1 |   2015 |
 201 |    2 |   2015 |
 ... |  ... |   2015 |     
 756 |  556 |   2015 |     <- last receipt in 2015
 757 |    1 |   2016 |     <- yearly counter restarted
Run Code Online (Sandbox Code Playgroud)

注意:RCID 是标准的 PK 自动递增字段。

sbr*_*bot 5

在@RickJames 的帮助下,解决方案是:

CREATE TRIGGER ReceiptNumber BEFORE INSERT ON receipts FOR EACH ROW
BEGIN
  SET NEW.rcyear=YEAR(NOW());
  SET NEW.rcno=(SELECT IFNULL(MAX(rcno),0)+1 FROM receipts WHERE rcyear=YEAR(NOW()));
END;
Run Code Online (Sandbox Code Playgroud)