web-dev-qa-db-fra.com

Comment faire en sorte que la clé primaire de la table MySQL s'incrémente automatiquement avec un préfixe

J'ai table comme ça

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

Je veux incrémenter mon champ id comme 'LHPL001','LHPL002','LHPL003'... etc. Que dois-je faire pour cela? S'il vous plaît laissez-moi savoir de toute façon possible.

63
Vijay

Si vous en avez vraiment besoin, vous pouvez atteindre votre objectif à l'aide d'un tableau séparé pour la séquence (si vous le voulez bien) et d'un déclencheur.

Les tables

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)
);

Maintenant la gâchette

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 ;

Ensuite, vous insérez simplement des lignes dans table1

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

Et vous aurez

 | ID | NOM | 
 ------------------ 
 | LHPL001 | Jhon | 
 | LHPL002 | Mark | 

Voici la démo SQLFiddle

111
peterm

Créez une table avec un ID auto_increment numérique normal, mais définissez-la avec ZEROFILL ou utilisez LPAD pour ajouter des zéros lors de la sélection. Ensuite, CONCAT les valeurs pour obtenir le comportement souhaité. Exemple 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 |
+---------+------+

Exemple n ° 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 |
+---------+------+
15
Fluffy

Je sais qu'il est tard mais je veux juste partager ce que j'ai fait pour cela. Je ne suis pas autorisé à ajouter une autre table ou un autre déclencheur, je dois donc la générer en une seule requête lors de son insertion. Pour votre cas, pouvez-vous essayer cette requête.

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

Effectuez une sélection et utilisez cette requête de sélection et enregistrez-la dans le paramètre @IDNUMBER.

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

Et puis la requête d'insertion sera:

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

Le résultat sera le même que l'autre réponse, mais la différence est que vous n'aurez pas besoin de créer une autre table ou un autre déclencheur. J'espère pouvoir aider quelqu'un qui a le même cas que le mien.

3
yhAm