AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Datenabgleich mit DB im Internet
Thema durchsuchen
Ansicht
Themen-Optionen

Datenabgleich mit DB im Internet

Ein Thema von manfred_h · begonnen am 15. Mär 2006 · letzter Beitrag vom 17. Mär 2006
Antwort Antwort
manfred_h

Registriert seit: 4. Nov 2005
Ort: Basel
442 Beiträge
 
Delphi XE2 Enterprise
 
#1

Datenabgleich mit DB im Internet

  Alt 15. Mär 2006, 11:07
Datenbank: Firebird • Version: 1.5 • Zugriff über: FibPLus
Hallo zusammen

habe folgende Überlegung:
Mysql im Internet ( muss auf einem normalen Webhoster sein / Linux)
Firebird lokal

Das Problem beim Upload der Daten ist, dass 2 Felder der Daten beim ( nach ) dem Upload überprüft werden müssen.
Das heisst:

SQL-Code:
  "ID"     "ID",
  "C_NR"  "T30" NOT NULL,
  "U_NR"  "T30" NOT NULL,
  "NAME"  "T130",
  "STR"     "T130",
  "PLZ"     "PLZ",
Das Feld C_NR und U_NR müssen mit dem angemeldeten User übereinstimmen. Da sonst das Problem besteht das ein User "ausversehen"
die Daten eines anderen überschreibt. ( Fals lokal dir Felder C_NR und U_NR falsch ausgefüllt sind darf kein Upload erfolgen /
die Werte müssen sich ändern lassen )
Ist dies mittels PHP möglich?
Kennt Ihr andere möglichkeinten? ( DIe auf einem normalen Webhoster einsetztbar sind / Linux )

Manfred
  Mit Zitat antworten Zitat
manfred_h

Registriert seit: 4. Nov 2005
Ort: Basel
442 Beiträge
 
Delphi XE2 Enterprise
 
#2

Re: Datenabgleich mit DB im Internet

  Alt 17. Mär 2006, 11:03
Hallo nochmals

habe bisher keine Lösung für mein Problem gefunden daher habe ich mir diesen Weg ausgemalt.

1 Master DB ( Mysql / im Internet )
x Client DBs ( Mysql / im Internet )

Es bestehen z.B für die CH 35 Gruppen jede Gruppe hat max. 10 User.
Jeder User hat nur Zugriff auf die Client DBs im Internet mit denen er die lokale DB Anwendung mittels eines PHP-Scripts Uploaded.
1-2x pro Tag werden mittels eines Cronjobs die Client DBs mit den Master DB Syncronisert.
In etwa so:
auf der Master DB alle Inhalte von Gruppe 123 löschen.
auf der Client DB alle im Feld dir Gruppennummer überprüfen und gegebenenfalls korrigieren.
alle Daten in die Master DB übertragen.

währe für Eure Kommentare Dankbar
Manfred
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#3

Re: Datenabgleich mit DB im Internet

  Alt 17. Mär 2006, 12:04
Hallo Manfred,

das ist alles sehr undurchsichtig. Vermutlich denken das auch noch andere Leser deines Beitrages. Kannst du deine Problembeschreibung noch etwas verbessern? Es läuft sonst auf ein Frage- und Antwortspiel hinaus, bevor ich etwas vernünftiges zu deinem Projekt schreiben kann. Dein Problem scheint nicht technischer, sonder eher organisatorischer Natur zu sein.

Wenn du deine Entscheidungen diskutieren möchtest, musst du auch die relevanten Entscheidungsgrundlagen aufzeigen.

Freundliche Grüße vom marabu
  Mit Zitat antworten Zitat
Benutzerbild von MrSpock
MrSpock
(Co-Admin)

Registriert seit: 7. Jun 2002
Ort: Owingen
5.865 Beiträge
 
Delphi 2010 Professional
 
#4

Re: Datenabgleich mit DB im Internet

  Alt 17. Mär 2006, 12:20
Hallo Manfred,

benutzt du jetzt Firebird und FibPlus oder MySQL? Diese Frage solltest du neben marabus Anregung auch noch beantworten.
Albert
Live long and prosper


MrSpock
  Mit Zitat antworten Zitat
manfred_h

Registriert seit: 4. Nov 2005
Ort: Basel
442 Beiträge
 
Delphi XE2 Enterprise
 
#5

Re: Datenabgleich mit DB im Internet

  Alt 17. Mär 2006, 13:29
Sorry, dass meine Problembeschreibung nicht verständlich genug war.
2ter Versuch

Aufgabe der Anwendung ist es, dass eine grosse Anzahl ( >100 ) von Anwendern Daten in eine
lokale DB Anwendung eingeben, welche dann mit einer DB im Internet abgeglichen wird.
Das ganze ist für eine Non-Profit Organisation und wird von mir als "Hobby" entwickelt.

Für die Schweiz sieht das so aus: ( wird später ( bei Erfolg ) erweitert )
35 Gruppen mit max. 10 Usern pro Gruppe.

Es besteht eine DB-Anwendung ( ist in der Entwickelung )
( Delphi ) mit einer firebird 1.5 DB als Backend mit Fibplus als Zugriffskomponente.

Local wird von jedem User manuell eingegeben in welcher Gruppe er ist und welche User ID er hat.
Diese Daten werden dann in der DB ( local ) automatisch in jeden Datensatz eingefügt.

SQL-Code:
z.B. "ID"  "ID", >> ist eine GUID
     "C_NR"  "T30" NOT NULL, >> 1234
     "U_NR"  "T30" NOT NULL, >> I1000
     "NAME"  "T130", >> Altersheim St.Johann
     "STR"  "T130", >> Feldstrasse 1
Problem:
Wenn der User falsche Daten eingiebt
( z.B. Gr. I1000 / Usr. 1234 ) anstelle von ( Gr. I1012 / Usr. 5678 )
und diese Daten auf den Server im Internet transferiert, überschreibt er die Daten des
womöglich schon vorhandenen Users ( Gr. I1000 / Usr. 1234 ). (( hoffe, das ist verständlich )

Im Internet möchte ich einen Server bei z.B. www.server4you.de anmieten ( besteht momentan noch nicht ).
Dort soll eine Haupt DB eingerichtet werden ( Mysql ) und die Client DB's ( Mysql )

Zitat:
jeder User hat nur Zugriff auf die Client DBs im Internet mit denen er die lokale DB Anwendung mittels eines PHP-Scripts Uploaded.
1-2x pro Tag werden mittels eines Cronjobs die Client DBs mit den Master DB syncronisert.
In etwa so:
auf der Master DB alle Inhalte von Gruppe 123 löschen.
auf der Client DB alle im Feld dir Gruppennummer überprüfen und gegebenenfalls korrigieren.
alle Daten in die Master DB übertragen.
Falls Fragen sind, bitte sagt es mir. Bin echt dankbar für Ideen.

Die Struktur der DB sieht so aus:

SQL-Code:
CREATE TABLE CAMPS
(
/***  "ID"     "ID" NOT NULL, ***/
  "C_NR"  "ID" NOT NULL,
  "U_NR"  "T30" NOT NULL,
  "CAMP"  "T50" NOT NULL,
  "REG"     "T50" NOT NULL,
  "REG_NAME"  "T50" NOT NULL,
  "CITY"     "T50" NOT NULL,
  "LANG"  "T50",
  "L_UPDATE"  "STATUS",
  "STAT_UPDATE"  INTEGER,
  "STAT_DEL"  INTEGER
);
SQL-Code:
/******************************************************************************/
/****                        ALTERSHEIM Start                              ****/
/****                       NURSING HOME Start                             ****/
/******************************************************************************/
CREATE TABLE NURSING_H
(
  "ID"     "ID",
  "C_NR"  "T30" NOT NULL,
  "U_NR"  "T30" NOT NULL,
  "NAME"  "T130",
  "STR"     "T130",
  "PLZ"     "PLZ",
  "CITY"     "T50",
  "TEL"     "T20",
  "FAX"     "T20",
  "EMAIL"  "T50",
  "HOMEPAGE"  "T130",
  "ANZ_PL"  "T10",
  "WORKER"  INTEGER,
  "MT"     "I_O",
  "ACCEPTANCE"  INTEGER,
  "STATUS"  INTEGER,
  "MEMO"  "TEXT",
  "NC"     "DATE",
  "CS"     INTEGER,
  "L_UPDATE"  "TIME_S",
  "STAT_UPDATE"  INTEGER,
  "STAT_DEL"  INTEGER
);

/******************************************************************************/
/****                          Primary Keys                                ****/
/******************************************************************************/

ALTER TABLE NURSING_H ADD PRIMARY KEY (ID);
ALTER TABLE NURSING_H ADD CONSTRAINT FK_NURSING_H1 FOREIGN KEY (C_NR) REFERENCES CAMPS (C_NR) ON UPDATE CASCADE;
/**ALTER TABLE NURSING_H ADD FOREIGN KEY ("U_NR") REFERENCES CAMPS ("U_NR") ON UPDATE CASCADE;**/

/******************************************************************************/
/****                          ALTERSHEIM END                              ****/
/****                         NURSING HOME END                             ****/
/******************************************************************************/


/******************************************************************************/
/****                    ALTERSHEIM KONTAKTE START                         ****/
/****                    NURSING HOME CONTAKT START                        ****/
/******************************************************************************/
CREATE TABLE NURSING_H_C
(
  "ID"     "ID",
  "C_NR"  "T30" NOT NULL,
  "U_NR"  "T30" NOT NULL,
  "ID_AREA"  "ID",
  "C_SALUT"  "T20",
  "C_NAME"  "T50",
  "C_FIRSTNAME"  "T50",
  "C_POSITION"  "T50",
  "C_TEL_1"  "T20",
  "C_TEL_2"  "T20",
  "C_EMAIL"  "T50",
  "C_MEMO"  "TEXT",
  "L_UPDATE"  "TIME_S",
  "STAT_UPDATE"  INTEGER,
  "STAT_DEL"  INTEGER
);

/******************************************************************************/
/****                   Primary Keys & REFERENCES                          ****/
/******************************************************************************/

ALTER TABLE NURSING_H_C ADD PRIMARY KEY (ID);
ALTER TABLE NURSING_H_C ADD CONSTRAINT FK_NURSING_H_C1 FOREIGN KEY (ID_AREA) REFERENCES NURSING_H (ID) ON DELETE CASCADE ON UPDATE CASCADE;
ALTER TABLE NURSING_H_C ADD CONSTRAINT FK_NURSING_H_C2 FOREIGN KEY (C_NR) REFERENCES CAMPS (C_NR) ON UPDATE CASCADE;

/******************************************************************************/
/****                     ALTERSHEIM KONTAKTE END                          ****/
/****                     NURSING HOME CONTACT END                         ****/
/******************************************************************************/


/******************************************************************************/
/****                   ALTERSHEIM VERTEILUNG START                        ****/
/****                 NURSING HOME DISTRIBUTION START                      ****/
/******************************************************************************/
CREATE TABLE NURSING_H_D
(
  "ID"     "ID",
  "C_NR"  "T30" NOT NULL,
  "U_NR"  "T30" NOT NULL,
  "ID_AREA"  "ID",
  "D_DATE"  "DATE",
  "D_C_PERSON"  "T50",
  "D_C_THRU"  "T130",
  "D_MEMO"  "TEXT",
  "L_UPDATE"  "TIME_S",
  "STAT_UPDATE"  INTEGER,
  "STAT_DEL"  INTEGER
);

/******************************************************************************/
/****                   Primary Keys & REFERENCES                          ****/
/******************************************************************************/

ALTER TABLE NURSING_H_D ADD PRIMARY KEY (ID);
ALTER TABLE NURSING_H_D ADD CONSTRAINT FK_NURSING_H_D1 FOREIGN KEY (ID_AREA) REFERENCES NURSING_H (ID) ON DELETE CASCADE ON UPDATE CASCADE;
ALTER TABLE NURSING_H_D ADD CONSTRAINT FK_NURSING_H_D2 FOREIGN KEY (C_NR) REFERENCES CAMPS (C_NR) ON UPDATE CASCADE;


/******************************************************************************/
/****                    ALTERSHEIM VERTEILUNG END                         ****/
/****                  NURSING HOME DISTRIBUTION END                       ****/
/******************************************************************************/


/******************************************************************************/
/****                 ALTERSHEIM VERTEILUNG DETAIL START                   ****/
/****               NURSING HOME DISTRIBUTION DETAIL START                 ****/
/******************************************************************************/
CREATE TABLE NURSING_H_DD
(
  "ID"     "ID",
  "C_NR"  "T30" NOT NULL,
  "U_NR"  "T30" NOT NULL,
  "ID_D"  "ID",
  "BIBEL_TYPE"  "T130",
  "AMOUNT"  INTEGER,
  "L_UPDATE"  "TIME_S",
  "STAT_UPDATE"  INTEGER,
  "STAT_DEL"  INTEGER
);


/******************************************************************************/
/****                   Primary Keys & REFERENCES                          ****/
/******************************************************************************/

ALTER TABLE NURSING_H_DD ADD PRIMARY KEY (ID);
ALTER TABLE NURSING_H_DD ADD CONSTRAINT FK_NURSING_H_DD1 FOREIGN KEY (ID_D) REFERENCES NURSING_H_D (ID) ON UPDATE CASCADE;
ALTER TABLE NURSING_H_DD ADD CONSTRAINT FK_NURSING_H_DD2 FOREIGN KEY (C_NR) REFERENCES CAMPS (C_NR) ON UPDATE CASCADE;


/******************************************************************************/
/****                  ALTERSHEIM VERTEILUNG DETAIL END                    ****/
/****                NURSING HOME DISTRIBUTION DETAIL END                  ****/
/******************************************************************************/
  Mit Zitat antworten Zitat
Antwort Antwort


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 17:26 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