Unterschiede
Hier werden die Unterschiede zwischen zwei Versionen angezeigt.
| Beide Seiten der vorigen Revision Vorhergehende Überarbeitung Nächste Überarbeitung | Vorhergehende Überarbeitung | ||
|
info:sek1:db-instahub [2020/12/14 09:05] demeny [Eigenen Hub erstellen] |
info:sek1:db-instahub [2021/01/24 17:50] (aktuell) demeny [Mithilfe des Datenbanksystems zum ER-Diagramm] |
||
|---|---|---|---|
| Zeile 62: | Zeile 62: | ||
| </callout> | </callout> | ||
| - | ===== Übung ===== | + | ===== Übung 1 ===== |
| <callout type="success" icon="glyphicon glyphicon-flag"> | <callout type="success" icon="glyphicon glyphicon-flag"> | ||
| Löse folgende Aufgaben und schreibe dir die SQL-Befehle ebenfalls in deinen digitalen Hefter. Kontrolliere die Anzahl der Ergebnisse mit der Vorgabe in Klammern. Diese Angaben gelten nur, wenn du bisher keine weiteren Änderungen an der Datenbasis vorgenommen hast. | Löse folgende Aufgaben und schreibe dir die SQL-Befehle ebenfalls in deinen digitalen Hefter. Kontrolliere die Anzahl der Ergebnisse mit der Vorgabe in Klammern. Diese Angaben gelten nur, wenn du bisher keine weiteren Änderungen an der Datenbasis vorgenommen hast. | ||
| Zeile 69: | Zeile 69: | ||
| - Gib die Anzahl an Fotos an, die in deinem Hub gespeichert sind. (1522) | - Gib die Anzahl an Fotos an, die in deinem Hub gespeichert sind. (1522) | ||
| - Zeige eine Tabelle, die die Städte der Benutzer*innen ausgibt. (204) | - Zeige eine Tabelle, die die Städte der Benutzer*innen ausgibt. (204) | ||
| - | - Manche Städt erscheinen mehrfach: Aus wie vielen verschiedenen Städten kommen die Nutzer*innen des Hubs? Informiere dich hierzu zum SQL-Befehl [[https://www.w3schools.com/sql/sql_distinct.asp|DISTINCT]]. (111) | + | - Manche Städte erscheinen mehrfach: Aus wie vielen verschiedenen Städten kommen die Nutzer*innen des Hubs? Informiere dich hierzu zum SQL-Befehl [[https://www.w3schools.com/sql/sql_distinct.asp|DISTINCT]]. (111) |
| - Welche der Städte ist bei alphabetischer Sortierung an erster Stelle? Informiere dich hierzu zum SQL-Befehl [[https://www.w3schools.com/sql/sql_orderby.asp|ORDER BY]]. (Albertshofen) | - Welche der Städte ist bei alphabetischer Sortierung an erster Stelle? Informiere dich hierzu zum SQL-Befehl [[https://www.w3schools.com/sql/sql_orderby.asp|ORDER BY]]. (Albertshofen) | ||
| - Erstelle eine Liste, die Benutzername und dazugehörige Stadt zeigt. Diese Übersicht soll absteigend nach Stadt sortiert sein. (204) | - Erstelle eine Liste, die Benutzername und dazugehörige Stadt zeigt. Diese Übersicht soll absteigend nach Stadt sortiert sein. (204) | ||
| Zeile 102: | Zeile 102: | ||
| FROM users | FROM users | ||
| ORDER BY centimeters DESC, name;</code> | ORDER BY centimeters DESC, name;</code> | ||
| + | </collapse> | ||
| + | |||
| + | ===== Übung 2 ===== | ||
| + | <callout type="success" icon="glyphicon glyphicon-flag"> | ||
| + | Bei den bisherigen Aufgaben genügte jeweils das Filtern von Daten in einer Tabelle - sogenannte einfache Abfragen. Nun soll es schrittweise schwieriger werden. Notiere dir neue Befehle und dazugehörige Beispiele in den Hefter. Los geht's: | ||
| + | - Gib aus, wie viele Mitglieder in Berlin wohnen. (14) Erweitere hierzu die SQL-Befehle um [[https://www.w3schools.com/sql/sql_where.asp|WHERE]] und nutze die Bedingung city="Berlin". Zusatztipp: Um eine elegantere Ausgabe zu erzeugen, nutzen wir in der Sekundarstufe II den SQL-Befehl COUNT(). | ||
| + | - Ersetze in der vorhergehenden Abfrage "=" zu "!=". Beschreibe, welche Änderung dies bewirkt. Betrachte dazu die Ausgabe der dazugehörigen Abfrage. (190) | ||
| + | - Ermittle alle Städte, die mit B beginnen. Informiere dich hier zum SQL-Befehl [[https://www.w3schools.com/sql/sql_like.asp|LIKE]] und den Platzhalter % sowie _. (31) | ||
| + | - Erstelle eine Übersicht aller Mitglieder, deren Namen auf "mann" endet. Ordne diese in alphabetisch aufsteigender Reihenfolge. (15) | ||
| + | - Frauen sind in Deutschland im Mittel 166 cm groß. Gib die Namen aller Nutzerinnen aus, die unterdurchschnittlich groß sind. (69) Um mehrere Bedingungen zu verknüpfen, informiere dich über die SQL-Befehle [[https://www.w3schools.com/sql/sql_and_or.asp|AND und OR]]. | ||
| + | - Männer sind in Deutschland im Mittel 180 cm groß. Gib die Namen aller Nutzer aus, die unterdurchschnittlich groß sind. (57) | ||
| + | - Verbinde die beiden vorhergehenden Abfragen und erzeuge so eine Liste mit allen "kleinen" Nutzer*innen. (126) Tipp: Klammern setzen. | ||
| + | - Finde heraus, welche Fotos die Nutzerin "stella439" kommentiert hat. Du kannst es Schritt für Schritt in ggf. mehreren Abfragen erledigen oder du gestaltest die Abfrage so geschickt, dass du sie in einer bündelst. Tipp: Du brauchst //users// und //comments// und solltest wissen, dass //users.id// und //comments.user_id// gleich sind. Hast du die Punktnotation bemerkt? | ||
| + | - Anna teilt ihrem Freund das nächste Urlaubsziel verschlüsselt mit: Die Initialien der Nutzerin, die mit "Kann man das Photo irgendwo kaufen?" kommentiert, weisen auf das Land unseres nächsten Urlaubs hin. Finde heraus, wohin die Reise geht. | ||
| + | </callout> | ||
| + | |||
| + | <button type="success" collapse="lsg_sql2">Lösung</button> | ||
| + | |||
| + | <collapse id="lsg_sql2" collapsed="true"> | ||
| + | - <code SQL>SELECT * | ||
| + | FROM users | ||
| + | WHERE city = "Berlin";</code> | ||
| + | - <code SQL>SELECT * | ||
| + | FROM users | ||
| + | WHERE city != "Berlin"; | ||
| + | -- "!=" steht für ungleich. Folglich werden alle Mitglieder*innen ausgegeben, die nicht in Berlin wohnen.</code> | ||
| + | - <code SQL>SELECT * | ||
| + | FROM users | ||
| + | WHERE city LIKE "B%"; | ||
| + | -- % ist ein Platzhalter für beliebig viele Zeichen. | ||
| + | -- _ ist ein Platzhalter für genau ein Zeichen.</code> | ||
| + | - <code SQL>SELECT * | ||
| + | FROM users | ||
| + | WHERE name LIKE "%mann" | ||
| + | ORDER BY name ASC;</code> | ||
| + | - <code SQL>SELECT name | ||
| + | FROM users | ||
| + | WHERE centimeters < 166 AND gender = "female"; | ||
| + | -- Durch die Und-Verknüpfung werden nur Dateneinträge gezeigt, die gleichzeitig beide Bedingungen erfüllen. Bei jedem Eintrag gilt also, dass die Person kleiner als 166 cm und weiblich ist. </code> | ||
| + | - <code SQL>SELECT name | ||
| + | FROM users | ||
| + | WHERE centimeters < 180 AND gender = "male";</code> | ||
| + | - <code SQL>SELECT name | ||
| + | FROM users | ||
| + | WHERE (centimeters < 166 AND gender = "female") OR (centimeters < 180 AND gender = "male"); | ||
| + | -- Die Klammerung bewirkt, dass beide Bedingungen getrennt voneinander bearbeitet werden. Durch die Oder-Verknüpfung werden dann alle Datensätze gelistet, bei denen die 1., die 2. oder beide Bedingungen erfüllt sind.</code> | ||
| + | - <code SQL>SELECT * | ||
| + | FROM users, comments | ||
| + | WHERE users.username = "stella439" AND users.id = comments.user_id; | ||
| + | -- Bei dieser Abfrage müssen zwei Tabellen abgefragt werden. Beide Tabellen haben die Nutzer-ID gemeinsam, weshalb gilt: users.id = comments.user_id. Da die Abfrage über mehrere Tabellen geht, müssen die Attribute mittels der Punktnotation der korrekten Tabelle zugeordnet werden. Dies kennst du bereits aus dem KOAM-Modell.</code> | ||
| + | - <code SQL>SELECT users.name | ||
| + | FROM users, comments | ||
| + | WHERE body LIKE "Kann man das Photo irgendwo kaufen?" AND users.id = comments.user_id AND users.gender = "female"; | ||
| + | -- Es erscheint: Greta Bauer mit den Initialien GB. Es geht also in das Vereinigte Königreich.</code> | ||
| + | </collapse> | ||
| + | |||
| + | |||
| + | ===== Mithilfe des Datenbanksystems zum ER-Diagramm ===== | ||
| + | Mittlerweile hast du einen Einblick in die Datenorganisation deines InstaHubs gewonnen. Aber wie schaut eigentlich das ER-Diagramm zu InstaHub aus? | ||
| + | |||
| + | <callout type="success" icon="glyphicon glyphicon-flag"> | ||
| + | Erstelle zuletzt das ER-Diagramm deines InstaHubs. Fokussiere dich auf die Zusammenhänge zwischen //users//, //photos//, //comments//, //likes// und //tags//. Lasse Attribute außen vor - notiere aber die Entitymengen, Beziehungen und Primärschlüssel. | ||
| + | </callout> | ||
| + | |||
| + | <button type="success" collapse="lsg_sql3">Lösungsvorschlag</button> | ||
| + | |||
| + | <collapse id="lsg_sql3" collapsed="true"> | ||
| + | Hier siehst du einen Lösungsvorschlag. Aus einem konkreten Datenbanksystem das ER-Modell zu erstellen, ist keine einfache Aufgabe. Deine Lösung weicht gegebenenfalls ab. Du solltest jedoch nachvollziehen können, wieso auch diese Variante möglich ist und insbesondere die Kardinalitätsangaben begründen können. | ||
| + | {{ :info:sek1:er-instahub.png?nolink |}} | ||
| </collapse> | </collapse> | ||