Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

OOP und Datenbankdesign

Mitglied: badrulecracker

badrulecracker (Level 1) - Jetzt verbinden

07.06.2007, aktualisiert 08.06.2007, 2763 Aufrufe, 1 Kommentar

Moin Moin,

ich habe da mal eine kleine Frage bezüglich des Datenbankdesigns in objekt orientierten Programmiersprachen.

Also ich habe gerade damit begonnen, mich mit oop zu beschäftigen (c# bzw php).

Wenn ich jetzt eine oo Software schreiben möchte und eine Datenbankanbindung realisieren will, komme ich bei der Datenbankkonzeption eigentlich immer auf das gleiche Ergebnis wie bei der Klassenkonzeption.

Beispiel:

Ich möchte eine Software erstellen, wo man Kunden hat, die Geräte entleihen können.
Also erstelle ich eine Klasse Kunde. Der hat Eigenschaften (Name, Vorname, Anschrift usw).
Dann vielleicht noch eine Klasse Geräte. Hier gibt es Eigenschaften (Gerätenummer, Name, Standort...)

Wenn ich dann das DB Konzept mir dafür überlege, würde ich auch eine Tabelle Kunde mit den Eigenschaften und eine Tabelle Geräte mit dessen Eigenschaften erstellen.
Ich frage mich nur, ob das der richtige Weg ist, seine Daten zu speichern in einer Objekt orientierten Umgebung.

Weil wenn man dann mit den Daten arbeitet und diese dann immer in die Objekte speichert, dann sind die Eigenschaften der Objekte ja sozusagen nur ein Zwischenspeicher.

Wie würde man in einer OO Umgebung vorgehen, würde man bei starten des Programmes alle Datensätze als Objekte instanziieren, oder immer nur bei Bedarf nachladen?



Über ein paar Anmerkungen würde ich mich freuen.

mfg, brc
Mitglied: AndreasHoster
08.06.2007 um 13:55 Uhr
Ich würde sagen, es kommt auf Deine Datenbank an wie man es genau macht, wobei ich bisher noch nie mit einer echten OO Datenbank gearbeitet habe, nur mit relationalen Datenbanken.

Jedenfalls ist die Idee, beim Progarmmstart alle Daten als Objekte zu instanziieren die -zensiert- Idee, die man haben kann, wenn die DB mehr als 2 Datensätze hat.
Der Arbeitsspeicherverbrauch und die Zeit zum Anlegen der Objekte dürfte beidesmal gigantisch sein, weil es ist kein trivialer Task mal kurz 100000 Objekte anzulegen (und 100000 Datensätze sind nicht viel).
Bei relationalen Datenbanken als Speicher ist es, wie Du sagst, daß die Eigenschaften praktisch nur Zwischenspeicher für die Daten sind. Wobei ich dann es gleich so machen würde, daß das Kundenobjekt seine Eigenschaften direkt aus dem Recordset der Datenbank zieht.
Also keine Methode, die die Tabelle einliest und dann x Objekte erzeugt, die von dem Recordset getrennt sind, dann könnte es nämlich passieren, daß in der DB die Daten sich geändert haben, im Objekt noch nicht und das wars dann mit Datenkonsistenz.

Wie es Objekt-Orientierte Datenbanken machen, weiß ich nicht, habe noch nie eine gesehen.
Bitte warten ..
Ähnliche Inhalte
PHP

Startschwierigkeiten bei OOP-Webentwicklung

Frage von coltseaversPHP2 Kommentare

Hallo zusammen, ich möchte gerade ehrenamtlich für einen Verein eine Online-Mitgliederverwaltung programmieren. Diese soll objektorientiert sein, da sie ständig ...

Neue Wissensbeiträge
iOS
IOS 11.2.6 verfügbar
Information von sabines vor 46 MinuteniOS

Mit dem Update soll der Bug behoben werden, bei dem eine bestimmte Zeichenkette IOS zum Absturz gebracht hat.

Sicherheit
Sicherheitsrisiko: Die Krux mit 7-Zip
Information von kgborn vor 15 StundenSicherheit

Bei vielen Anwendern ist das Tool 7-Zip zum Entpacken von Archivdateien im Einsatz. Die Software ist kostenlos und steht ...

Internet

Datendealing im WWW Tracking Methoden immer brutaler

Information von sabines vor 1 TagInternet

Interessanter Artikel zum Thema Tracking im WWW und die immer "besseren" Methoden des Trackings. Professor Arvind Narayanan (Princeton-Universität) betreibt ...

Erkennung und -Abwehr

Ups: Einfaches Nullzeichen hebelte den Anti-Malware-Schutzt in Windows 10 aus

Information von kgborn vor 1 TagErkennung und -Abwehr

Windows 10 ist das sicherste Windows aller Zeiten, wie Microsoft betont. Insidern ist aber klar, das es da Lücken, ...

Heiß diskutierte Inhalte
Server
Route-Befehl Unterstützung (unter CMD)
gelöst Frage von FKRR56Server37 Kommentare

Guten Tag , i.M. habe ich Probleme über den CMD-Route-Befehl ein Routing auf einen entfernten Server zuzulassen. Der Server ...

Windows 10
Windows 10 (1709) Tastur und Maus wieder einschalten?
Frage von LochkartenstanzerWindows 1028 Kommentare

Moin, Ich habe von einem Kunden einen Win10-Rechner bekommen, bei dem weder Tastatur noch Maus geht. Die Hardware funktioniert ...

Microsoft
TV-Tipp: Das Microsoft-Dilemma
Information von kgbornMicrosoft17 Kommentare

Aktuell gibt es in Behörden und in Firmen eine fatale Abhängigkeit von Microsoft und dessen Produkten. Planlos agieren die ...

Webbrowser
Welcher Browser ist der Beste?
Frage von justtinWebbrowser15 Kommentare

Hallo Leute Ich habe eine interessante Frage. Mich wurde mal interessieren welcher Browser ist eure meinung nach der beste? ...