AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Mandantenfähigkeit nachrüsten - Design?
Thema durchsuchen
Ansicht
Themen-Optionen

Mandantenfähigkeit nachrüsten - Design?

Ein Thema von DeddyH · begonnen am 15. Nov 2008 · letzter Beitrag vom 17. Nov 2008
Antwort Antwort
Seite 2 von 2     12   
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#11

Re: Mandantenfähigkeit nachrüsten - Design?

  Alt 15. Nov 2008, 11:51
Dann sollte es reichen, die m:n-Beziehung wie von dir aufgezeigt zu modellieren. Am Rest der DB müsste dann ja nichts geändert werden.
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.619 Beiträge
 
Delphi 12 Athens
 
#12

Re: Mandantenfähigkeit nachrüsten - Design?

  Alt 15. Nov 2008, 11:54
Danke, ich denke auch, dass das so die beste Variante ist.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von joachimd
joachimd

Registriert seit: 17. Feb 2005
Ort: Weitingen
678 Beiträge
 
Delphi 12 Athens
 
#13

Re: Mandantenfähigkeit nachrüsten - Design?

  Alt 15. Nov 2008, 14:28
kleiner Denkanstoß, der in eine etwas andere Richtung geht:
Du hast eine Applikation, welche nicht Mandantenfähig ist (Kunde, Artikel, ... plus zentrale Tabellen, wie PLZ, BLZ usw).
1. Schritt: Jeder Mandant bekommt sein eigenes Eco-System, also eine unabhängige Datenbank (DBMandant1, DBMandant2, ...)
2. Schritt: Du baust eine Einstiegs-DB auf (DBZentral, zB mit Mandanten-Auswahl-Tabelle und den Pfaden zu bzw Namen der Datenbanken - ja nach System).
3. Schritt: Du extrahierst die zentralen Tabellen in die Zentral-DB (zB um die PLZ, BLZ nicht jedesmal pflegen zu müssen).
4. Schritt: Da nun in den Mandanten diese Tabellen fehlen, ersetzt Du diese durch Views auf die Tabellen der Zentral-DB - fertig (create view plz as select * from zentraldb.plz)

Alles, was Du in der Applikation nun ändern musst, ist ein neues Startfenster, das sich zur ZentralDB verbindet und die Mandantenauswahl anbietet. Ist ein Mandant ausgewählt, verbindest Du den Rest (also alles wie bisher) mit der Mandanten-DB.

Auf diese Weise habe ich schon einige mit der heißen Nadel gestrickten Applikationen umstellen lassen und innerhalb kürzester Zeit Mandanten-fähig gemacht.

Forgot: Du musst natürlich auch eine kleine Mandanten-Verwaltung einbauen (neuer, leerer Mandant anlegen, Mandant löschen, Mandant bearbeiten usw).

[edit]
habe gerade gesehen, dass du ja schon etwas relativiert hast...aber ich lasse das posting trotzdem als Anregung, falls einer so was sucht [/edit]
Joachim Dürr
Joachim Dürr Softwareengineering
http://www.jd-engineering.de
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.619 Beiträge
 
Delphi 12 Athens
 
#14

Re: Mandantenfähigkeit nachrüsten - Design?

  Alt 15. Nov 2008, 14:31
Soweit wollte ich jetzt nicht gehen, aber der Ansatz ist schon ganz schön tricky, das werde ich mir auf jeden Fall mal merken.
Herzlichen Dank .
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#15

Re: Mandantenfähigkeit nachrüsten - Design?

  Alt 15. Nov 2008, 14:40
Zitat:
1. Schritt: Jeder Mandant bekommt sein eigenes Eco-System, also eine unabhängige Datenbank (DBMandant1, DBMandant2, ...)
Fände ich zu umständlich
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von joachimd
joachimd

Registriert seit: 17. Feb 2005
Ort: Weitingen
678 Beiträge
 
Delphi 12 Athens
 
#16

Re: Mandantenfähigkeit nachrüsten - Design?

  Alt 15. Nov 2008, 14:49
Zitat von mkinzler:
Zitat:
1. Schritt: Jeder Mandant bekommt sein eigenes Eco-System, also eine unabhängige Datenbank (DBMandant1, DBMandant2, ...)
Fände ich zu umständlich
kommt auf das DBMS an .. ich präferiere aus bekannten Gründen ADS, und da kann ich dann einfach per XCopy eines leeren Mandaten (bzw Backup-Restore mit "MetaOnly" eines normalen Mandanten) einen neuen erstellen ... ohne allzuviel Arbeit, da die DB auch nicht am Server attached wird.
Aber zum Glück ist und bleibt das Geschmackssache <g>
Joachim Dürr
Joachim Dürr Softwareengineering
http://www.jd-engineering.de
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#17

Re: Mandantenfähigkeit nachrüsten - Design?

  Alt 17. Nov 2008, 10:43
Hallo DeddyH,

bei mir sieht Mandantenfähigkeit im Prinzip so aus:
  • Jeder Mandant hat seine eigene Datenbank (bzw. ein eigenes Datenbankschema, wenn mehrere Mandanten den gleichen Datenbankserver benutzen).
  • Für gemeinsame Daten (Steuerdaten) gibt es ein Schema, dass in jeder Datenbank einmal vorhanden ist und mandantenübergreifend genutzt wird (Bankleitzahlen, Postdaten...) können hier untergebracht werden. Steuertabellen für die Mandantenauswahl, also alles dass, was das Programm selbst zum prinzipiellen Funktionieren benötigt.
Alles was mandantenspezifisch ist und sich prinzipiell von Mandant zu Mandant unterscheiden kann, kommt in das Schema des Mandanten, auch wenn hierdurch ggfls. Redundanzen entstehen können. Kein Mandant kann/darf Daten ändern, die auch andere Mandanten betreffen könnten. Hierdurch ist der Umzug eines Mandanten auf einen anderen Datenbankserver immer möglich. Er benötigt das "Steuerschema" und sein Datenschema, d. H. seine Daten sind immer eindeutig identifizierbar und separat sicherbar.
Bei einer Mischung von mehrere Mandanten in einem Schema mit gemeinsamer Nutzung von Tabellen, müsste man ja hier erstmal "seine" Daten zusammensuchen und dann noch streng von den Daten der anderen Mandanten trennen. Dies dürfte bei mehreren Mandanten eine nicht mehr so ganz triviale Angelegenheit sein. Ob die Mischung mehrere Mandanten in einem Schema mit gemeinsamer Tabellennutzung noch als revisionssicher zu bezeichnen ist, vermag ich nicht zu beurteilen.

Stell' Dir mal vor, alle Mandanten benutzen ein Schema und nun hat einer der Mandanten seine Daten zersemmelt, wie willst Du da mit vertretbarem Aufwand ein Restore hinbekommen, wenn Du Teilmengen sämtlicher Tabellen ersetzen musst, aber keinesfalls die Daten anderer Mandanten verändern darfst.

Gehen wir mal davon aus, Du benutzt ADO als Schnittstelle, dann benötigst Du zwei AdoConnections in Deinem Programm, eine für das "Steuerschema" und eine für das Datenschema. Da es datentechnisch eigentlich keine Verbindung zwischen den beiden Schemata geben darf, ist die Trennung nicht problematisch. Daten (Bankleitzahlen...) aus dem "Steuerschema" können in dem Programm "nur" als Nachschlagtabelllen angeboten werden. Werden solche Daten ins Datenschema übernommen, so werden sie dort redundant abgelegt und nicht in Form von Fremdschlüsselbeziehungen. Sind die Fremdschlüsselbeziehungen zwingend erforderlich, so müssen die Steuerdaten (Bankleitzahlen...) Teil des Datenschemas werden, da hier mandantenspezifische Unterschiede auftreten können. Eine Normalisierung der Daten findet nur auf Mandantenebene statt und nicht mandantenübergreifen.

So tricky ist das Ganze dann eigentlich doch nicht
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.619 Beiträge
 
Delphi 12 Athens
 
#18

Re: Mandantenfähigkeit nachrüsten - Design?

  Alt 17. Nov 2008, 11:14
Hallo Stephan, da hast du natürlich recht, aber das ist in meinem Fall nicht die Anforderung. Es geht vielmehr darum, die Bewegungsdaten auseinander halten zu können, da reicht mein im Ausgangspost geschildertes Design vollkommen aus.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 18:54 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz