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 自动递增字段。
在@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)
| 归档时间: |
|
| 查看次数: |
1712 次 |
| 最近记录: |