sql >> Databasteknik >  >> RDS >> Mysql

Grundläggande MySQL-frågor

Du kan prova frågorna påhttp://sqlfiddle.com/#!9/839d2/1

Fråga 1

Lista över alla planeter som har kaptener. Den visar id_planet, planet_name, totala kaptener på var och en av dessa planeter samt antalet strider (om några) som ägde rum där.

SELECT DISTINCT aa.id_planet, aa.planet_name, _aa.captains_count, _bb.battles_count
FROM planet AS aa
INNER JOIN soldier AS bb
ON aa.id_planet = bb.planet_id
INNER JOIN (
    SELECT planet_id, COUNT(*) AS captains_count
    FROM soldier
    WHERE rank = 'captain'
    GROUP BY planet_id
) AS _aa
ON aa.id_planet = _aa.planet_id
LEFT JOIN (
    SELECT id_planet_battle, COUNT(*) AS battles_count
    FROM battle
    GROUP BY id_planet_battle
) AS _bb
ON aa.id_planet = _bb.id_planet_battle
WHERE bb.rank = 'captain';

Du kan få samma resultat med detta:

SELECT DISTINCT aa.id_planet, aa.planet_name,
(
    SELECT COUNT(*)
    FROM soldier AS _aa
    WHERE _aa.rank = 'captain' AND aa.id_planet = _aa.planet_id
    GROUP BY _aa.planet_id
) AS captains_count,
(
    SELECT COUNT(*)
    FROM battle AS _bb
    WHERE aa.id_planet = _bb.id_planet_battle
    GROUP BY _bb.id_planet_battle 
) AS battles_count
FROM planet AS aa
INNER JOIN soldier AS bb
ON aa.id_planet = bb.planet_id
WHERE bb.rank = 'captain';

Fråga 3

SELECT aa.name, aa.rank, bb.planet_name AS planet_from, (
    SELECT COUNT(*) 
    FROM soldier AS _aa 
    WHERE _aa.planet_id = aa.planet_id
) AS number_of_soldiers, 
(
    SELECT COUNT(*)
    FROM battle AS _bb
    WHERE _bb.id_planet_battle = aa.planet_id
) AS number_of_battles
FROM soldier AS aa
INNER JOIN planet AS bb
ON aa.planet_id = bb.id_planet;

Här använde jag inte Joins för att beräkna antal_soldater och antal_strider som jag gjorde i fråga 1.1 eftersom det skulle vara en korrelerad underfråga och som sådan kunde den inte ha tillgång till de yttre frågorna (https://dev.mysql.com/doc/refman/5.5/en/from-clause -subqueries.html ).

Fel fråga:

SELECT DISTINCT aa.id_planet, aa.planet_name, _aa.captains_count, _bb.battles_count
FROM planet AS aa
INNER JOIN soldier AS bb
ON aa.id_planet = bb.planet_id
INNER JOIN (
    SELECT COUNT(*) AS captains_count
    FROM soldier AS _aa
    WHERE _aa.rank = 'captain' AND aa.id_planet = _aa.planet_id
    GROUP BY _aa.planet_id
) AS _aa
ON aa.id_planet = _aa.planet_id
LEFT JOIN (
    SELECT COUNT(*) AS battles_count
    FROM battle AS _bb
    WHERE aa.id_planet = _bb.id_planet_battle
    GROUP BY _bb.id_planet_battle 
) AS _bb
ON aa.id_planet = _bb.id_planet_battle
WHERE bb.rank = 'captain';

Så ovanstående fråga är felaktig och ger felet:Okänd kolumn 'aa.id_planet' i 'where-sats'.

När det gäller den andra frågan du frågade efter hoppas jag att någon annan kan prova.




  1. Gruppera utdata från VISA KOLUMNER i en kommaavgränsad lista

  2. Laravels enkla månadsval

  3. Hur man ändrar prioritet för samtidiga program

  4. MySQL konverterar kolumndatatyp från VARCHAR till INT