sql >> Database >  >> RDS >> Mysql

Draaitafel Met 3 tafels

Het lijkt erop dat u een onbekend aantal vergoedingen heeft dat u in kolommen wilt omzetten. Als dat het geval is, wilt u voorbereide verklaringen gebruiken om dit op te vragen:

SET @sql = NULL;
SELECT
  GROUP_CONCAT(DISTINCT
    CONCAT(
      'max(case when f.fee_name = ''',
      f.fee_name,
      ''' then f.fee_amount else 0 end) AS `',
      f.fee_name, '`'
    )
  ) INTO @sql
FROM fee f;

SET @sql = CONCAT('SELECT s.school_id, ', @sql, '
                    , sum(f.fee_amount) as Total
                  FROM students s
                  LEFT JOIN stud_fee sf
                    on s.id = sf.stud_id
                  LEFT JOIN fee f
                    on sf.fee_id = f.id
                   GROUP BY s.school_id');


PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;

Zie SQL Fiddle met demo



  1. Maak verbinding met externe MySQL db vanuit de docker-container

  2. Ondersteuning voor JSON in Oracle 11g

  3. JDBC converteert Timestamp naar NULL (probleem met nulDateTimeBehavior)

  4. Het hernoemen van een enumwaarde resulteert in Type Relatie Niet gevonden