Mysql
 sql >> Database >  >> RDS >> Mysql

Esiste una singola query in grado di aggiornare un numero di sequenza su più gruppi?

Puoi usare un'altra variabile che memorizza il type_id precedente (@type_id ). La query è ordinata per type_id , quindi ogni volta che c'è un cambiamento in type_id , la sequenza deve essere reimpostata su 1.

Set @seq = 0;
Set @type_id = -1;

Update `log`
Set `sequence` = If(@type_id=(@type_id:=`type_id`), (@seq:[email protected]+1), (@seq:=1))
Order By `type_id`, `created_at`;