如何使用某些前缀使MySQL表主键自动递增

我有这样的桌子

table

id Varchar(45) NOT NULL AUTO_INCREMENT PRIMARY KEY,

name CHAR(30) NOT NULL,

我想增加我的id字段,例如'LHPL001','LHPL002','LHPL003'…等。我该怎么做?请让我知道任何可能的方式。

回答:

如果您确实需要此功能,则可以借助单独的表进行排序(如果您不介意的话)和触发器来实现您的目标。

桌子

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)

);

现在触发

DELIMITER $$

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$$

DELIMITER ;

然后您只需将行插入到table1

INSERT INTO Table1 (name) 

VALUES ('Jhon'), ('Mark');

然后你会

| ID | NAME |

------------------

| LHPL001 | 俊|

| LHPL002 | 马克|

这是 演示

以上是 如何使用某些前缀使MySQL表主键自动递增 的全部内容, 来源链接: utcz.com/qa/413933.html

回到顶部