如何使用一些前缀使MySQL表主键自动增加

Vij*_*jay 64 mysql auto-increment

我有这样的表

table
id Varchar(45) NOT NULL AUTO_INCREMENT PRIMARY KEY,
name CHAR(30) NOT NULL,
Run Code Online (Sandbox Code Playgroud)

我想增加我的id字段,比如'LHPL001','LHPL002','LHPL003'......等等.我应该为此做些什么?请让我知道任何可能的方式.

pet*_*erm 112

如果您真的需要这个,您可以通过单独的表格(如果您不介意)和触发器来实现您的目标.

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)
);
Run Code Online (Sandbox Code Playgroud)

现在是触发器

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 ;
Run Code Online (Sandbox Code Playgroud)

然后你只需要向table1插入行

INSERT INTO Table1 (name) 
VALUES ('Jhon'), ('Mark');
Run Code Online (Sandbox Code Playgroud)

你会有的

|      ID | NAME |
------------------
| LHPL001 | Jhon |
| LHPL002 | Mark |

这是SQLFiddle演示

  • 触发器内的语句是原子的吗?即,在 INSERT 和 SET 之间,另一个线程/请求插入 table1_seq 是否有可能导致 LAST_INSERT_ID() 返回另一个请求的 id,而不是在 BEGIN/END 中插入的 id。 (2认同)

Flu*_*ffy 15

创建一个具有普通数字auto_increment ID的表,但要么用它定义,要么在选择时ZEROFILL使用LPAD添加零.然后CONCAT是值以获得您的预期行为.示例#1:

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 |
+---------+------+
Run Code Online (Sandbox Code Playgroud)

示例#2:

create table so (
 id int unsigned 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', LPAD(id, 3, 0)) as id, name from so;
+---------+------+
| id      | name |
+---------+------+
| LHPL001 | John |
| LHPL002 | Mark |
+---------+------+
Run Code Online (Sandbox Code Playgroud)


yhA*_*hAm 6

我知道已经晚了,但我只想分享我为此所做的一切。我不允许添加另一个表或触发器,因此我需要在插入时在单个查询中生成它。对于您的情况,您可以尝试这个查询吗?

CREATE TABLE YOURTABLE(
IDNUMBER VARCHAR(7) NOT NULL PRIMARY KEY,
ENAME VARCHAR(30) not null
);
Run Code Online (Sandbox Code Playgroud)

执行选择并使用此选择查询并保存到参数@IDNUMBER

(SELECT IFNULL
     (CONCAT('LHPL',LPAD(
       (SUBSTRING_INDEX
        (MAX(`IDNUMBER`), 'LHPL',-1) + 1), 5, '0')), 'LHPL001')
    AS 'IDNUMBER' FROM YOURTABLE ORDER BY `IDNUMBER` ASC)
Run Code Online (Sandbox Code Playgroud)

然后插入查询将是:

INSERT INTO YOURTABLE(IDNUMBER, ENAME) VALUES 
(@IDNUMBER, 'EMPLOYEE NAME');
Run Code Online (Sandbox Code Playgroud)

结果将与其他答案相同,但不同之处在于,您不需要创建另一个表或触发器。我希望能帮助到和我有同样情况的人。