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

Comment utiliser l'incrémentation automatique dans le type de données Varchar en PHP et MYSQL ?

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