MYSQL 5.7.5:
Puoi raggiungere l'obiettivo utilizzando Colonne generate e questo .
Non testato
CREATE TABLE TEST (
ProdID VARCHAR(20) AS CONCAT('PR','',PID) STORED,
PID INT auto_increment)
Per tua comodità,
MSSQL:
Il metodo più semplice è semplicemente creare una colonna calcolata. Utilizza quella che è nota come colonna "calcolata" insieme a una colonna 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;
Ciò restituisce quanto segue (notare che l'incremento automatico ha funzionato):
ProdID ProdName
------------------------------ ------------------------------
PR001 Thread
PR002 Button Thread
PR003 Coat Thread