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 ****/
/******************************************************************************/