MYSQL 5.7.5:
Możesz osiągnąć cel, używając Generowanych kolumn i to .
Nie testowano
CREATE TABLE TEST (
ProdID VARCHAR(20) AS CONCAT('PR','',PID) STORED,
PID INT auto_increment)
Dla Twojej wygody
MSSQL:
Najłatwiejszą metodą jest po prostu wykonanie kolumny obliczeniowej. Używa tak zwanej kolumny „obliczonej” w połączeniu z kolumną 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;
To zwraca następujące informacje (zwróć uwagę, że auto-inkrementacja zadziałała):
ProdID ProdName
------------------------------ ------------------------------
PR001 Thread
PR002 Button Thread
PR003 Coat Thread