我有这样的桌子
table id Varchar(45) NOT NULL AUTO_INCREMENT PRIMARY KEY, name CHAR(30) NOT NULL,
我想增加我的id字段,例如'LHPL001','LHPL002','LHPL003'…等。我该怎么做?请让我知道任何可能的方式。
'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 | 马克|
这是 SQLFiddle 演示