MySQL触发器 - 年 - 月(YYMM)前缀+自动增量ID

时间:2014-04-21 21:40:01

标签: mysql triggers

我看到另一篇文章解释了使用触发器来创建前缀ID How to make MySQL table primary key auto increment with some prefix

  

http://sqlfiddle.com/#!2/0ed88/1

我是触手可及的新手,我想知道是否有一种方法可以让前缀为年 - 月(YYMM)而不是预设的4个字母" LHPL"如在SQLfiddle中写的那样?

非常感谢!在这个mysql之旅中学到很多东西!

    CREATE TABLE table1_seq
    (
      id INT NOT NULL AUTO_INCREMENT PRIMARY KEY
    )|

    CREATE TABLE Table1
    (
      id VARCHAR(7) NOT NULL PRIMARY KEY DEFAULT '0', name VARCHAR(30)
    )|


    CREATE TRIGGER tg_table1_insert
    BEFORE INSERT ON table1
    FOR EACH ROW
    BEGIN
      INSERT INTO table1_seq VALUES (NULL);
      SET NEW.id = CONCAT('LHPL', LPAD(LAST_INSERT_ID(), 3, '0'));
    END |


    INSERT INTO Table1 (name) VALUES ('Jhon'), ('Mark')|

1 个答案:

答案 0 :(得分:1)

替换

'LHPL'

DATE_FORMAT(NOW(),'%y%m')

此处记录了NOW()DATE_FORMAT()函数:

参考:http://dev.mysql.com/doc/refman/5.5/en/date-and-time-functions.html