Mysql
 sql >> база данни >  >> RDS >> Mysql

Как да преизчислим поле в ГРУПА

Мисля, че това трябва да стане:

INSERT INTO mapped (f1_new, f2_new, fk_new)
SELECT f1_new, f2_new, fk_new from (
    SELECT f1_new, @f2 := if(f1_new = @prev_f1, @f2+1, 0) f2_new, fk_new, @prev_f1 := f1_new
    FROM (select f1 AS f1_new, CASE WHEN fk IN (100, 200) THEN 'A'
                                    WHEN fk in (300, 400) THEN 'B'
                                    WHEN fk = 500 THEN 'C'
                               END AS fk_new
          FROM origin
          GROUP BY f1_new, fk_new
          ORDER BY f1_new, fk_new) new,
         (SELECT @f2 := NULL, @prev_f1 := NULL) vars
    ) x

FIDDLE




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Вмъкване на данни от предния край към mysql db в angularjs

  2. АКТУАЛИЗИРАНЕ на MYSQL с IN и подзаявка

  3. имплодирайте масив в разделен със запетая низ от mysql заявката

  4. MySQL пагинация без двойна заявка?

  5. MySQL инжекция от LIKE оператор