Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

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
GELÖST

Interbase db replikation...

Frage Entwicklung Datenbanken

Mitglied: dax4fun

dax4fun (Level 1) - Jetzt verbinden

29.08.2014, aktualisiert 16:24 Uhr, 1109 Aufrufe

Hi, Leute

brauche eure Hilfe, habe als Aufgabe eine Interbase6 Table bekommen, wo ich wenn eine neue Zeile dazukommt, die ganze Zeile in eine andere DB replizieren soll, die identisch aufgebaut ist.

Dieser neuer Eintrag (Zeile), kommt alle 5 min als fortlaufender event und datums Eintrag, weitere 20+ Einträge sind noch mit an Board (EVENT täglich von 2 bis 288 am nächsten Tag wieder 2-288 )

01.
GRTIME                   GRNUMBER          GRRACENUMBERIX     GRFIRST    GRSECOND    GRODD_001  
02.
25.08.2014 00:05:00               2         749481002          4           5        1502 
03.
25.08.2014 00:10:00               3         749481003          5           1        1302
habe mir gedacht das per "stored procedure " zu machen (da wenn event da schnell replizieren!! ) habe eine solche gefunden die vorhanden war, davon will ich eine txt Datei und per isql in die andere db rein

01.
# vorhandene procedure 
02.
 
03.
CONNECT 'D:\ESDS\Database\CONTROLDESK.IB' USER 'SYSDBA' PASSWORD 'masterkey'; 
04.
/* 
05.
 * Exceptions. 
06.
 */  
07.
CREATE EXCEPTION FAILED_TO_CREATE_FILE 'File could not be created.'; 
08.
CREATE EXCEPTION FAILED_TO_WRITE_FILE 'File could not be written.'; 
09.
 
10.
 
11.
/* 
12.
 * Procedure to write file: <TICKETNUMBER>.txt 
13.
 */  
14.
SET TERM ^ ; 
15.
CREATE PROCEDURE WRITE_TICKET_FILE (ticketNumber CHAR(40), ticketAmount INTEGER, isCancel INTEGER) 
16.
AS 
17.
  DECLARE VARIABLE printerSerialNumber VARCHAR(32); 
18.
  DECLARE VARIABLE path VARCHAR(128); 
19.
  DECLARE VARIABLE filename VARCHAR(256); 
20.
  DECLARE VARIABLE filehandle INTEGER; 
21.
  DECLARE VARIABLE retwrite INTEGER; 
22.
  DECLARE VARIABLE retclose INTEGER; 
23.
  DECLARE VARIABLE newline VARCHAR(4); 
24.
  DECLARE VARIABLE content VARCHAR(4096); 
25.
  DECLARE VARIABLE contentAmountFloat FLOAT; 
26.
  DECLARE VARIABLE contentAmountStr VARCHAR(32); 
27.
  DECLARE VARIABLE contentStatus VARCHAR(8); 
28.
  DECLARE VARIABLE contentLength INTEGER; 
29.
BEGIN 
30.
 
31.
  /* 
32.
   * Configure following PARAMETERs: 
33.
   */    
34.
  printerSerialNumber = '1234567890123456'; 
35.
  path = 'C:\\TICKETS\\'; 
36.
   
37.
  /* 
38.
   * From here no further changes needed 
39.
   */    
40.
  newline = CHR(10); 
41.
   
42.
  filename = path || ticketNumber || '.txt'; 
43.
 
44.
  filehandle = FOPEN(filename, BITOR(FO_CREAT(), FO_RDWR()));   
45.
  IF (filehandle >= 0) THEN 
46.
    BEGIN 
47.
       
48.
      contentStatus = ''; 
49.
      IF (isCancel = 1) THEN 
50.
        BEGIN 
51.
          contentStatus = '1;1;'; 
52.
        END 
53.
       
54.
      contentAmountFloat = ticketAmount; 
55.
      contentAmountStr = contentAmountFloat / 100; 
56.
      contentAmountStr = TRIM(contentAmountStr); 
57.
      contentAmountStr = SUBSTR(contentAmountStr, 1, STRPOS('.',contentAmountStr)+2); 
58.
       
59.
      content = '350,1,______,_,__;+6 Broj listica:;' || newline || 
60.
                '350,1,______,_,__;+7 ' || SUBSTR(ticketNumber, 0, 21) || ';' || newline || 
61.
                '350,1,______,_,__;+8 ' || SUBSTR(ticketNumber, 21, 21) || ';' || newline || 
62.
                '48,1,______,_,__;' || printerSerialNumber || ';1;0000;' || contentStatus || newline || 
63.
                '52,1,______,_,__;1;' || contentAmountStr || ';0.00;' || newline || 
64.
                '53,1,______,_,__;' || newline || 
65.
                '56,1,______,_,__;' || newline; 
66.
       
67.
      contentLength = STRLEN(content); 
68.
       
69.
      retwrite = FWRITE(filehandle, content); 
70.
      IF (retwrite <> contentLength) THEN 
71.
        BEGIN 
72.
          retclose = FCLOSE(filehandle); 
73.
          EXCEPTION FAILED_TO_WRITE_FILE; 
74.
        END 
75.
       
76.
      retclose = FCLOSE(filehandle); 
77.
    END 
78.
  ELSE 
79.
    BEGIN 
80.
      EXCEPTION FAILED_TO_CREATE_FILE; 
81.
    END 
82.
     
83.
END 
84.
85.
SET TERM ; ^
01.
# meine Interpretation ;) 
02.
/* 
03.
 * Exceptions. 
04.
 */  
05.
CREATE EXCEPTION FAILED_TO_CREATERESULT_FILE 'File could not be created.'; 
06.
CREATE EXCEPTION FAILED_TO_WRITERESULT_FILE 'File could not be written.'; 
07.
 
08.
 
09.
/* 
10.
 * Procedure to write file: <TICKETNUMBER>.txt 
11.
 */  
12.
SET TERM ^ ; 
13.
CREATE PROCEDURE WRITE_RESULT_FILE (ticketNumber CHAR(40), ticketAmount VARCHAR(4096)) 
14.
AS 
15.
   
16.
  DECLARE VARIABLE path VARCHAR(128); 
17.
  DECLARE VARIABLE filename VARCHAR(256); 
18.
BEGIN 
19.
  path = 'C:\\RESULTS\\'; 
20.
  filename = path || ticketNumber || ticketAmount || '.txt'; 
21.
  FOPEN(filename); 
22.
  FWRITE(filename); 
23.
FCLOSE(filename); 
24.
END 
25.
26.
SET TERM ; ^
Ähnliche Inhalte
Hyper-V
gelöst Erfahrungsaustausch zu Hyper-V-Replikation (28)

Frage von DerWoWusste zum Thema Hyper-V ...

Windows Server
gelöst DFS-Replikation - Problem ohne Adminrechte (4)

Frage von mario01 zum Thema Windows Server ...

Hyper-V
Server 2016 Hyper-V Replikation (10)

Frage von Falko82 zum Thema Hyper-V ...

Datenbanken
SQL 2000 DB ist Fehlerverdächtig (3)

Frage von franksig zum Thema Datenbanken ...

Neue Wissensbeiträge
Windows Tools

Zeit für Energiesparmodus, Bildschirmabschaltung etc. schnell anpassen

Anleitung von hannsgmaulwurf zum Thema Windows Tools ...

Linux Netzwerk

Ping und das einstellbare Bytepattern

(1)

Erfahrungsbericht von LordGurke zum Thema Linux Netzwerk ...

Windows Update

Microsoft Update KB4034664 verursacht Probleme mit Multimonitor-Systemen

(4)

Tipp von beidermachtvongreyscull zum Thema Windows Update ...

Heiß diskutierte Inhalte
Firewall
Richtige Grundeinstellungen der Pfsense für mein Netzwerk (12)

Frage von Spitzbube zum Thema Firewall ...

Switche und Hubs
gelöst Cisco 2960x Stacking über mehrere Etagen (12)

Frage von b3scher zum Thema Switche und Hubs ...