CDS104-Databases-and-Data-P.../code/online-part-2b/MongoDB_Aufgabe_Daten.ipynb
2025-05-18 19:41:37 +02:00

151 lines
4.1 KiB
Plaintext

{
"cells": [
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Zoo-Verwaltung in MongoDB\n",
"\n",
"In diesem Beispiel soll die einfache Zoo-Verwaltung aus der Aufgabe zuvor in MongoDB umgesetzt werden. \n",
"\n",
"Installieren Sie dazu zunächst MongoDB auf Ihrem Rechner, hier finden Sie den Download und die Dokumentation zur Installation:\n",
"https://www.mongodb.com/try/download/community\n",
"\n",
"Um MongoDB in Python zu verwenden, benötigen Sie das Modul `pymongo`. Installieren Sie es mit dem folgenden Befehl:\n",
"\n",
" conda install conda-forge::pymongo\n",
"\n"
]
},
{
"cell_type": "code",
"execution_count": 1,
"metadata": {},
"outputs": [],
"source": [
"# Client importieren\n",
"from pymongo import MongoClient"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"# TODO: Mit dieser Zelle können Sie testen, ob die Verbindung zur MongoDB-Datenbank funktioniert.\n",
"\n",
"# Verbindungsaufbau zu einer MongoDB-Datenbank\n",
"client = MongoClient('localhost', 27017)\n",
"\n",
"# Zoo-Datenbank erstellen\n",
"db = client['zoo']\n",
"\n",
"# Beispiel-Dokument in Collection 'animals' erstellen\n",
"db.animals.insert_one({'name': 'Ella', 'species': 'elephant'})\n",
"\n",
"# Alle Dokumente in Collection 'animals' ausgeben\n",
"for animal in db.animals.find():\n",
" print(animal)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Teilaufgabe 1 (4 Punkte): \n",
"\n",
"Fügen Sie im folgenden Dokumente ein, die die selben Informationen enthalten wie in der Aufgabe zuvor. Dabei sollen drei Tiere mit zwei Tierpfegern erstellt werden. Ein Tierpfleger versorgt mehrere Tiere, jedes Tier ist genau einem Tierpfleger zugeordnet. Ob Sie die Daten dabei normalisieren oder nicht, bleibt Ihnen überlassen."
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"# TODO: Einfügen von Daten:\n",
"\n",
"# db.animals.insert_one(...)\n",
"# db.animals.insert_many(...)\n",
"\n",
"# Falls Sie mehrere Collections nutzen...\n",
"\n",
"# db.zookeeper.insert_one(...)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Teilaufgabe 2 (3 Punkte): \n",
"\n",
"Erstellen Sie jetzt noch eine Funktion, die einen Überblick über alle Tiere im Zoo gibt, die Ausgabe soll dabei dem Beispiel ähneln."
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"# TODO: Ausgabe aller Daten\n",
"def zoo_overview():\n",
" pass\n",
"\n",
"# Beispielausgabe:\n",
"#\n",
"# ----------------------------------------\n",
"# | Babar | Elephant | John Doe |\n",
"# | Dumbo | Elephant | John Doe |\n",
"# | Hathi | Elephant | John Doe |\n",
"# | Melman | Giraffe | Jane Doe |\n",
"# | Gloria | Giraffe | Jane Doe |\n",
"# ----------------------------------------\n",
"\n",
"# Testaufruf\n",
"zoo_overview()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Teilaufgabe 3 (3 Punkte): \n",
"\n",
"Begründen Sie, warum Sie die Struktur der Datenbank so gewählt haben, wie Sie es getan haben. \n",
"\n",
"Welche Vor- und Nachteile hat Ihre Lösung (für volle Punktzahl sollten Sie mindestens 2 Vor- und 2 Nachteile nennen)?\n"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Antwort: "
]
}
],
"metadata": {
"kernelspec": {
"display_name": "code (3.13.2)",
"language": "python",
"name": "python3"
},
"language_info": {
"codemirror_mode": {
"name": "ipython",
"version": 3
},
"file_extension": ".py",
"mimetype": "text/x-python",
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
"version": "3.13.3"
}
},
"nbformat": 4,
"nbformat_minor": 2
}