首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何使MySQL表主键带前缀自动递增

如何使MySQL表主键带前缀自动递增
EN

Stack Overflow用户
提问于 2013-07-27 11:38:04
回答 3查看 375.5K关注 0票数 86

我有一张这样的桌子

代码语言:javascript
复制
table
id Varchar(45) NOT NULL AUTO_INCREMENT PRIMARY KEY,
name CHAR(30) NOT NULL,

我想像'LHPL001','LHPL002','LHPL003'一样递增我的id字段...等等。我应该为此做些什么呢?请告诉我任何可能的方法。

EN

回答 3

Stack Overflow用户

发布于 2015-03-03 05:56:32

创建一个具有普通数字auto_increment ID的表,但可以使用ZEROFILL对其进行定义,或者在选择时使用LPAD添加零。然后CONCAT这些值以获得您想要的行为。示例#1:

代码语言:javascript
复制
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:

代码语言:javascript
复制
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 |
+---------+------+
票数 18
EN

Stack Overflow用户

发布于 2017-03-10 10:37:20

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

代码语言:javascript
复制
CREATE TABLE YOURTABLE(
IDNUMBER VARCHAR(7) NOT NULL PRIMARY KEY,
ENAME VARCHAR(30) not null
);

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

代码语言:javascript
复制
(SELECT IFNULL
     (CONCAT('LHPL',LPAD(
       (SUBSTRING_INDEX
        (MAX(`IDNUMBER`), 'LHPL',-1) + 1), 5, '0')), 'LHPL001')
    AS 'IDNUMBER' FROM YOURTABLE ORDER BY `IDNUMBER` ASC)

然后Insert查询将是:

代码语言:javascript
复制
INSERT INTO YOURTABLE(IDNUMBER, ENAME) VALUES 
(@IDNUMBER, 'EMPLOYEE NAME');

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

票数 3
EN

Stack Overflow用户

发布于 2020-07-21 21:06:25

如果有人在PostgreSQL上需要触发器,下面是不带触发器的PostgreSQL示例:

代码语言:javascript
复制
CREATE SEQUENCE messages_seq;

 CREATE TABLE IF NOT EXISTS messages (
    id CHAR(20) NOT NULL DEFAULT ('message_' || nextval('messages_seq')),
    name CHAR(30) NOT NULL,
);

ALTER SEQUENCE messages_seq OWNED BY messages.id;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17893988

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档