如何使MySQL表的主键自动递增

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (16)

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 ;

然后,只需将行插入到表1。

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

你会有

|      ID | NAME |
------------------
| LHPL001 | Jhon |
| LHPL002 | Mark |
用户回答回答于

使用普通数字自动创建表_增量ID,但要么用ZEROFILL,或使用LPAD若要在选择时添加零,请执行以下操作。然后CONCAT获取您预期行为的值。例子:

create table so (
 id int(3) unsigned zerofill not null auto_increment primary key,
 name varchar(30) not null
);

insert into so set name = 'John';
insert into so set name = 'Mark';

select concat('LHPL', id) as id, name from so;
+---------+------+
| id      | name |
+---------+------+
| LHPL001 | John |
| LHPL002 | Mark |
+---------+------+

扫码关注云+社区