sql >> Database >  >> RDS >> Mysql

MySQL - Converteer een dubbele waarde naar een unieke waarde met een incrementele aaneenschakeling

Het lijkt erop dat je gewoon CONCAT() de waarden samen:

select data, group_row_number, 
  concat(data, cast(group_row_number as char)) as num,
  overall_row_num
from
(
  select data,
        @num := if(@data = `data`, @num + 1, 1) as group_row_number,
        @data := `data` as dummy, overall_row_num
  from
  (
    select data, @rn:[email protected]+1 overall_row_num
    from yourtable, (SELECT @rn:=0) r
  ) x
  order by data, overall_row_num
) x
order by overall_row_num

Zie SQL Fiddle met demo



  1. Vind ontbrekende gegevens die zijn doorgegeven aan SQL in de zin

  2. CSV-gegevens importeren in de Rails-app, met iets anders dan de associatie-ID

  3. Geheugenfout bij gebruik van json.dumps()

  4. Meerdere rijen invoegen in één SQL-query?