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

Mysql auto-incrémente une colonne avec une clé primaire spécifique

Afin d'obtenir ce que vous recherchez, vous devez utiliser déclencheurs . Il n'y a pas d'autre moyen direct d'accomplir cette tâche (je suppose).

J'ai essayé une démo rapide maintenant :

Create Table SoQuestion (
  UserId int,
  PostId int,
  PostNumber int null
 );

 CREATE TRIGGER inc_post_num 
 BEFORE INSERT ON SoQuestion
 FOR EACH ROW
 set New.PostNumber = (select num 
                       From (select count(*) as num 
                             from SoQuestion 
                             where UserId = New.UserId) as b) 
                     + 1;


insert into SoQuestion (UserId, PostId) Values (1,1);
insert into SoQuestion (UserId, PostId) Values (1,10);
insert into SoQuestion (UserId, PostId) Values (1,20);
insert into SoQuestion (UserId, PostId) Values (2,1);
insert into SoQuestion (UserId, PostId) Values (2,10);
insert into SoQuestion (UserId, PostId) Values (3,1);
insert into SoQuestion (UserId, PostId) Values (4,1);

select * FROM SoQuestion;

Et voici la sortie que j'ai obtenue :

UserId | PostId | PostNumber |
==============================  
1      | 1      | 1          |
1      | 10     | 2          |
1      | 20     | 3          |
2      | 1      | 1          |
2      | 10     | 2          |
3      | 1      | 1          |
4      | 1      | 1          |

Voici la démo .

Après avoir parcouru le Auto_Increment documentation, j'ai trouvé un autre moyen d'y parvenir sans utiliser de déclencheurs. L'idée est de créer un Auto_Increment colonne et ajoutez-la avec une autre colonne comme PRIMARY KEY . Dans notre cas, ce serait UserId et le AUTO_INCREMENT serait PostNumber et ils forment tous les deux la clé primaire. Voici comment :

Create Table SoQuestion (
  UserId int,
  PostId int,
  PostNumber int NOT NULL AUTO_INCREMENT,
  PRIMARY KEY (UserId, PostNumber)
 );

insert into SoQuestion (UserId, PostId) Values (1,1);
insert into SoQuestion (UserId, PostId) Values (1,10);
insert into SoQuestion (UserId, PostId) Values (1,20);
insert into SoQuestion (UserId, PostId) Values (2,1);
insert into SoQuestion (UserId, PostId) Values (2,10);
insert into SoQuestion (UserId, PostId) Values (3,1);
insert into SoQuestion (UserId, PostId) Values (4,1);

select * FROM SoQuestion;

Cela nous donnerait le même résultat que la première méthode :

UserId | PostId | PostNumber |
==============================  
1      | 1      | 1          |
1      | 10     | 2          |
1      | 20     | 3          |
2      | 1      | 1          |
2      | 10     | 2          |
3      | 1      | 1          |
4      | 1      | 1          |

Et voici la démo pour la deuxième manière.