Mysql
 sql >> Base de données >  >> RDS >> Mysql

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

Si vous en avez vraiment besoin, vous pouvez atteindre votre objectif à l'aide d'un tableau séparé pour le séquençage (si cela ne vous dérange pas) et d'un déclencheur.

Tableaux

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 le déclencheur

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 | NAME |
------------------
| LHPL001 | Jhon |
| LHPL002 | Mark |

Voici SQLFiddle démo