MYSQL 5.7.5 :
Vous pouvez atteindre l'objectif en utilisant Colonnes générées et ceci .
Non testé
CREATE TABLE TEST (
ProdID VARCHAR(20) AS CONCAT('PR','',PID) STORED,
PID INT auto_increment)
Pour votre commodité,
MSSQL :
La méthode la plus simple consiste à créer simplement une colonne calculée. Il utilise ce que l'on appelle une colonne "calculée" conjointement avec une colonne IDENTITY.
CREATE TABLE Test
(
ProdID AS CAST('PR'+RIGHT('000'+CAST(RowNum AS VARCHAR(3)),3) AS VARCHAR(30)) PERSISTED
,ProdName VARCHAR(30)
,RowNum INT IDENTITY(1,1)
);
INSERT INTO Test (ProdName)
SELECT 'Thread' UNION ALL
SELECT 'Button Thread' UNION ALL
SELECT 'Coat Thread';
SELECT ProdID, ProdName FROM Test;
Cela renvoie ce qui suit (notez que l'auto-incrémentation a fonctionné) :
ProdID ProdName
------------------------------ ------------------------------
PR001 Thread
PR002 Button Thread
PR003 Coat Thread