Unsere Datenschutzrichtlinie wird in Kürze aktualisiert. Bitte sehen Sie sich die Vorschau an.

Access 2016 Grundkurs

Diskussion der Datenbank

Testen Sie unsere 2019 Kurse

10 Tage kostenlos!

Jetzt testen Alle Abonnements anzeigen
Obwohl sich mit Access schnell eine Datenbank entwerfen lässt, ist das nicht sinnvoll. Alle Datenbanken brauchen zwingend ein vorbereitetes Konzept, um Fehler zu vermeiden. Bereits die wenigen Daten des Beispiels sind problematisch.

Transkript

Das ganze sieht nun schon wie eine richtige Datenbank aus. Es gibt eine Tabelle und ein paar schöne Abfragen dazu. Jetzt ist es mehr als dringend Zeit, sich das ganze mal kritisch anzusehen und zwar vor allem die Tabelle. Die Abfragen, das kann ich jetzt schon versprechen, können wir nachher alle wieder löschen, die Probleme liegen nämlich in der Tabelle. Ich werde die mit Doppelklick mal öffnen, und damit wir ein bisschen besser sehen, auf den ganzen Bildschirm verbreitern und ich habe schon paar weitere Datensätze eingegeben, damit sie sehen, wie schnell sie sich Probleme einhandeln. Fangen wir vielleicht an mit dem Telefonfeld. Normalerweise scheint es so, dass sie genau eine Telefonnummer haben und wenn die anruft dann wissen sie, welche Adresse das ist. Ich habe aber selber zum Beispiel mehrere Telefonnummern, im gleichen Haus, das ist heute überhaupt nicht unüblich und je nach dem, von wo aus ich anrufen, vielleicht habe ich auch mal von der Faxnummer bestellt, ist der gleiche Empfänger unter unterschiedlichen Telefonnummern zu erreichen und die einfachste Möglichkeit, damit man das nicht mehrfach notieren muss, istnatürlich das hier rein zu schreiben und das geht nicht. Wenn sie so etwas machen, dann können Sie nie wieder herausbekommen, wie viele Telefonnummern hier wirklich drin stehen. Ich kann beispielsweise mal schnell eine Abfrage erstellen, das geht auch wenn hier die Tabelle offen ist, also erstellen Abfrageentwurf, basiert immer noch auf Lieferung. Und sagen wir mal ich beschäftige mich nur mit dem Feld Telefon. Und will jetzt alle Telefonnummern finden, wir können das hier mal eben gucken, die das 67890 Enthalten. Also würde ich dort schreiben, die Vorwahl ist mir egal *67890*, da darf was davor oder dahinter stehen, vielleicht geht die Telefonnummer nochmal weiter und kann das hier in der Ansicht ansehen. Ich kriege dabei auch Telefonnummern, die diesem Schema nicht entsprechen. 67890 habe ich verlangt, natürlich steht hier vorne auch die passende Nummer, aber diese zählt zum Beispiel nicht dazu. Und wenn ich jetzt als nächstes frage: Wie viele Telefonnummern habe ich eigentlich, dann lautet die Antwort der Datenbank drei und meine Augen sagen mir vier, es ist also mit Datenbankmethoden gar nicht abzufragen, welche und wie viele Telefonnummern da überhaupt drin sind. Das ist das erste Problem. Ich kann diese Abfrage jetzt hier ungespeichert schließen. Nein die will ich nicht speichern. Also die Tatsache, dass ich hier mehrere Inhalte rein schreiben möchte, vielleicht sogar muss, ist ein Unding in einer Datenbank, damit lässt es sich nicht arbeiten. Das passiert hier hinten übrigens auch, wenn, meinetwegen nur mit einer einzigen Telefonnummer, alles andere ist super, hier mehrere Sachen bestellt werden, dann könnte man direkt hintereinander schreiben und könnte sich hier zusammen ausrechnen: 5, 20 €und 4 € macht 9, 20 €. Die erste Frage, die man sich stellt, ist warum muss ich das eigentlich ausrechnen, ich sitze gerade vor einem Rechner, der kann das ja wohl. Und zweitens kann ich nie wieder trennen, das Hier zwei Inhalte drin stehen und die vorherige Lösung für diesen Fall sah so aus, dass ich zwei Datensätze angelegt hatte, indem ich ganz viel doppelt eingetragen hatte, gleiche Telefonnummer, gleiche Adresse gleicher Fahrer, gleiches Datum. Und zwar nur deswegen, damit ich diese beiden Probleme in zwei Datensätze verteile und keine Probleme mehr habe, ich kann genau sagen eine Portion Spaghetti und dreimal Pizza Margarita, während ich hier nur hoffen kann, dass beide genau gleich oft auftauchen, wenn hier eine Zwei steht, ist es schon missverständlich, ob es jetzt meint eine Pizza Margarita, eine Pizza con tutto oder zweimal Pizza Margarita und zweimal Pizza con tutto. Das wäre völlig unkalkulierbar, ich kann die weder einzeln angeben, noch irgendwie zählen und muss auch noch selber rechnen. Dann geht es direkt weiter, hier ist ein Schreibfehler drin. Ich mach mal wieder eine neue Abfrage, also Erstellen Abfrageentwurf, immer noch basierend auf Lieferung. Und sagen wir ruhig Sternchen, ich will alle Datensätze sehen, deren Adresse nicht doppelt angezeigt wird, aber irgendwie Bahnhofs allerdings mit Sternchen, Sternchen, Bahnhofsstraße usw. enthält. Sternchen sagt davor und dahinter darf ein beliebige Eintrag sein. Nach dem Return steht ein wie, ein Ähnlichkeitsvergleich, dazu also alle, die in der Adresse das Wort Bahnhofsstraße enthalten und dann zählen wir doch mal. Das ist jetzt relativ einfach, das kann ich schon direkt sehen, aber ich sage schon mal hier unten steht die Zahl, die ich wissen will, insgesamt 2 Datensätze. Jetzt gucken wir mal auf die Texte drauf: 1 2 3, sehen sie den Fehler? Hier ist es eine Bahnhofsstraße und hier ist es eine Bahnhofstraße. Wenn sie also eine freie Dateneingabe erlauben, müssen sie immer damit rechnen, dass es Schreibfehler gibt. Sehr beliebt ist zum Beispiel, verschiedene Schreibweisen eines Ortes: ich komme aus Aachen, das heißt Aachen, aber as gibt auch die Bezeichnung Bad Aachen. Wird heute nicht mehr so oft gebraucht, aber es ist eine Kurstadt und auf manche Adressen steht Bad Aachen und manche geben auch den Stadtteil an wenn man Aachener ist, weiß man das Burtscheit ein Stadtteil ist. Je nach dem wer fragt, würde ich einem Aachener nie erklären, dass ich in Aachen wohne, sondern detailliert, ein Pizzadienst liefert dann aus Aachen, sagen ihr müsst nach Burtscheit kommen, dann wissen die schon mal die Entfernung. Und solche Adressen, die entweder Aachen oder Bad Aachen oder Burtscheit heißen können sind furchtbar, wenn sie die verwalten wollen. Hier ist es nur ein Schreibfehler, an anderen Stellen ist es vielleicht sogar Absicht, dass es unterschiedliche Beschreibungen des gleichen Ortes gibt. Eines der Probleme haben wir immerhin schon gelöst, es sind ja reichlich drin hier, hier zum Beispiel die Schreibfehler beim Fahrer oder bei der Fahrerin sind deswegen nicht mehr relevant, weil die aus einer Liste kommen. Ich kann, wenn ich jetzt versuche irgendwann einen Namen einzugeben, der nicht in der Liste steht, kann ich nicht aus dem Datensatz, nicht mal aus dem Feld kommen, wenn ich mit der Tab-Taste jetzt weiter gehe, gibt es direkt eine Fehlermeldung. Ich könnte die jetzt ergänzen, aber nein, das will ich nicht, ich muss jetzt mit Escape diese Änderung verlieren und das ist eigentlich auch schon der Weg oder die Richtung, in die es gehen soll, ich muss die Datenbank so begrenzen das es keine Fehler mehr gibt. Denn dieses scheinbare Begrenzen ist eigentlich eine Befreiung: Sie grenzen die Fehlermöglichkeiten der Datenbank ein und befreien sich davon von einer Menge Probleme. Es gibt hier noch mehr, sie können zum Beispiel, wenn sie etwas von der Speisekarte wählen, dann können Sie erstmal eigentlich nicht sagen, was es kostet. Ich habe das aus dem Gedächtnis oder von einem Zettel vor meinen Augen abgetippt. Und das ist eigentlich auch nicht sinnvoll, ich könnte die Speisekarte hier irgendwo hinterlegen und sobald ich auf Pizza con tutto gehe, ist der Preis klar, das sind sogenannte abhängige Daten, übrigens auch die Postleitzahl und der Ort, wenn es irgendjemandem hier gelingen sollte sowas wie eine völlig andere Postleitzahl einzugeben und den gleichen Ort zu nennen, das muss ein Fehler sein. Sie können zwar im gleichen Ort mehrere Postleitzahlen haben, aber noch krasser, ich geh mal mit Escape raus, wäre es wenn sie, was weiß ich, nehmen wir hier den Ort mit der Postleitzahl fünf mal die 9. Und der heißt dann nicht Hiermund, sondern Dortmund. Das kann nicht sein, dass die gleiche Postleitzahl einen anderen Ort meint. Ganz ehrlich, bei Postleitzahlen ist es tatsächlich so, dass es in ländlichen Gebieten noch alte Ortsbezeichnung gibt, wo es mehrere mit dergleichen Postleitzahl gibt, aber tatsächlich ist hier eine Abhängigkeit, ich mach das mit Escape mal wieder rückgängig, sobald ich eine Postleitzahl angebe, ist der Ort eigentlich klar, damit ist auch die Vorwahl eigentlich klar. Und genauso, wenn ich etwas von der Speisekarte angebe, ist der Preis klar, das muss ich gar nicht, sollte ich gar nicht nachgucken dürfen. Und wenn sie einen Datensatz herausfischen wollen, aus irgendeinem Grund, dann können Sie ihn entweder mühsam über seine Details eingeben: Ich suche das, was Maria am 4. 12. in die Straße hinter dem Mond gebracht hat oder sie haben vielleicht eine eindeutige Nummer, das ist viel einfacher Es gibt sogar Datenbanken, die verhindern beispielsweise Löschaktionen, solange es nicht eine eindeutige Nummer für den Datensatz gibt. Man kann Mehrfachschlüssel machen, also einen Datensatz, der an mehreren Elementen zu erkennen ist, aber grundsätzlich ist es viel viel einfacher ein neues Feld zu machen, welches ganz banal durchnummeriert wird. Das ist der Autowert, wenn wir uns damit beschäftigen, und der wird dann sogenannter primär Schlüssel, das Wort kann ich auch schon mal erwähnen, also derjenige Schlüssel, der für diesen Datensatz der eindeutigste ist und damit verbindlich gegenüber der Datenbank. Der wird intern durchnummeriert, damit haben sie nichts zu tun, sie sagen einfach nur der soll da sein. Und auch das vereinfacht die Arbeit erheblich. Wir haben also rundum Probleme, wenige Felder in einer einzigen Tabelle und mehr Probleme, als ich an einer Hand abzählen kann, da muss ich also erheblich was ändern und das bedeutet, wir müssen uns vorher mit dem Datenmodell beschäftigen, also welche Daten werden eigentlich warum wo gespeichert.

Access 2016 Grundkurs

Erwerben Sie die notwendigen Kenntnisse, um mit Access 2016 leistungsfähige Datenbanken zu erstellen.

6 Std. 18 min (75 Videos)
Derzeit sind keine Feedbacks vorhanden...
 

Dieser Online-Kurs ist als Download und als Streaming-Video verfügbar. Die gute Nachricht: Sie müssen sich nicht entscheiden - sobald Sie das Training erwerben, erhalten Sie Zugang zu beiden Optionen!

Der Download ermöglicht Ihnen die Offline-Nutzung des Trainings und bietet die Vorteile einer benutzerfreundlichen Abspielumgebung. Wenn Sie an verschiedenen Computern arbeiten, oder nicht den ganzen Kurs auf einmal herunterladen möchten, loggen Sie sich auf dieser Seite ein, um alle Videos des Trainings als Streaming-Video anzusehen.

Wir hoffen, dass Sie viel Freude und Erfolg mit diesem Video-Training haben werden. Falls Sie irgendwelche Fragen haben, zögern Sie nicht uns zu kontaktieren!