为了账号安全,请及时绑定邮箱和手机立即绑定

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

/ 猿问

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

潇潇雨雨 2019-10-12 07:07:39

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

我有这样的表

tableid Varchar(45) NOT NULL AUTO_INCREMENT PRIMARY KEY,name CHAR(30) NOT NULL,

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


查看完整描述

3 回答

?
白衣非少年

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

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 table1FOR EACH ROWBEGIN
  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 | Jhon || LHPL002 | 马克|

这是SQLFiddle演示



查看完整回答
反对 回复 2019-10-13
?
慕村225694

创建一个具有普通数字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 |

+---------+------+

示例#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 |

+---------+------+



查看完整回答
反对 回复 2019-10-13
?
慕瓜9086354

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

CREATE TABLE YOURTABLE(IDNUMBER VARCHAR(7) NOT NULL PRIMARY KEY,ENAME VARCHAR(30) not null);

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

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

然后插入查询将是:

INSERT INTO YOURTABLE(IDNUMBER, ENAME) VALUES (@IDNUMBER, 'EMPLOYEE NAME');

结果与其他答案相同,但区别在于,您不需要创建另一个表或触发器。我希望我可以帮助那些和我有同样情况的人。



查看完整回答
反对 回复 2019-10-13

添加回答

回复

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信