AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Insert Generator bei Interbase klappt nicht !
Thema durchsuchen
Ansicht
Themen-Optionen

Insert Generator bei Interbase klappt nicht !

Ein Thema von wlfmario · begonnen am 23. Jan 2006 · letzter Beitrag vom 24. Jan 2006
Antwort Antwort
Seite 2 von 4     12 34      
Benutzerbild von tomsel
tomsel

Registriert seit: 8. Dez 2005
Ort: am Chiemsee
304 Beiträge
 
Delphi 7 Professional
 
#11

Re: Insert Generator bei Interbase klappt nicht !

  Alt 23. Jan 2006, 18:39
Zitat von wlfmario:
Da liegt ja das Problem !
Ich habe es schon in allen Variationen versucht, entweder meckert Delphi oder Interbase.
DM.IBShop.InsertSQL.Text :=('INSERT INTO SHOPDATEN (NAME) VALUES 'MARIO' '); Ich habe das gefühl das ich etwas übersehe.


DM.IBShop.InsertSQL.Text :='INSERT INTO SHOPDATEN (NAME) VALUES (''MARIO'') ';
Ein Experte ist ein Mann, der hinterher genau sagen kann, warum seine Prognose nicht gestimmt hat. (Winston Churchill)
  Mit Zitat antworten Zitat
wlfmario

Registriert seit: 5. Jan 2005
Ort: Pulheim
115 Beiträge
 
#12

Re: Insert Generator bei Interbase klappt nicht !

  Alt 23. Jan 2006, 19:02
Danke das war es !

Leider wird nichts in der DB Eingetragen. Es werden auch keine Fehler angezeigt.
Mario
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Insert Generator bei Interbase klappt nicht !

  Alt 23. Jan 2006, 19:09
-hast du ein Commit der Transaktion ausgefüht oder steht diese auf AutoCommit?
Von was für einen Typ ist IBShop? Nehm mal ein IBQuery - Komponente
Delphi-Quellcode:
DM.IBShop.Close;
DM.IBShop.SQL.Text :='INSERT INTO SHOPDATEN (NAME) VALUES '+QuotedStr('Mario')+')';
DM.IBShop.ExecSql;
Markus Kinzler
  Mit Zitat antworten Zitat
wlfmario

Registriert seit: 5. Jan 2005
Ort: Pulheim
115 Beiträge
 
#14

Re: Insert Generator bei Interbase klappt nicht !

  Alt 23. Jan 2006, 19:48
Ich benutze die IBDataSet.

Ein Commit habe ich mal eingefügt hat aber nichts gebracht.
Mario
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Insert Generator bei Interbase klappt nicht !

  Alt 23. Jan 2006, 19:57
IBDataSet.Insert; einfügen.
Markus Kinzler
  Mit Zitat antworten Zitat
wlfmario

Registriert seit: 5. Jan 2005
Ort: Pulheim
115 Beiträge
 
#16

Re: Insert Generator bei Interbase klappt nicht !

  Alt 23. Jan 2006, 20:08
Bringt auch nichts !Leider ....
Werde mal auf die Datensteuerung Kompos umstellen, damit klappt das eigendlich immer.
Bleibt nur die Frage wieso das jetzt nicht klappen will. So viele Fehler können doch nicht im Projekt sein.
Selbst mein Interbase Buch weis keine Lösung.
Mario
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Insert Generator bei Interbase klappt nicht !

  Alt 23. Jan 2006, 20:45
IBDatSet ist eine kombinierte Kompoenente, welche eiun ähnliches Verhalten simuliert wie eien BDE-Table.
Basis eist eine Selectabfrage.
Wird nun eine .Insert Befehl ausgeführt wird die Anweisung in der InsertSQL - Eigenschaft ausgeführt, bei .Update UpdateSQL usw.
Für eine einfache DML-Anweisung verwendet man eine einfache IBQuery:
Delphi-Quellcode:
 IBdatabase.Open;
 IBQuery.SQL.Text :='INSERT INTO SHOPDATEN (NAME) VALUES ('+QuotedStr('Mario')+')';
 IBTransaction.StartTransaction;
 IBQuery.ExecSql;
 IBTransaction.Commit;
Achtung .Open nur bei Select sonst .ExecSQL
Markus Kinzler
  Mit Zitat antworten Zitat
Hansa

Registriert seit: 9. Jun 2002
Ort: Saarland
7.554 Beiträge
 
Delphi 8 Professional
 
#18

Re: Insert Generator bei Interbase klappt nicht !

  Alt 23. Jan 2006, 20:50
Da liegt ein grober Denkfehler vor ! Entweder der Trigger ist dafür zuständig, die ID hochzuzählen, oder man macht es von Hand zu Fuß. Ergo : wird die ID von Hand geändert und ist deshalt NOT NULL, dann kann der schönste Trigger nichts ausrichten, der den Generator mit :

SQL-Code:
I IF (NEW.ID IS NULL) THEN
    NEW.ID = GEN_ID(GEN_SHOPDATEN_ID,1);
END
aktualisiert. Im Zusammenhang mit dem von Hand gemachten INSERT sieht es dann richtig öde aus. Wozu hat ein TDataset denn eigene Methoden (hier : Insert) um den Krempel ohne Schreibfehler zu machen ? Falsch zusammengebaute SQL-Statements sind Delphi nämlich schlichtweg egal ! Merke : Finger weg von den IDs im eigenen Programm (natürlich außer lesen). Noch zur Klarstellung : Generatoren enthalten nur Werte und sind auch transaktionsunabhängig. Rollback/Commit usw. gilt für die nicht ! Die BI-Trigger sind deshalb hervorragend dazu geeignet, die Generatorenwerte hochzuzählen. Bei mir wird da gleich noch der timestamp eines neu angelegten Datensatzes usw. mit gespeichert. Man kann auch sonstige Werte setzen. Die Möglichkeiten gehen weit über das schlichte Paradox-Autoincrement hinaus. Außerdem gibt es in IB/FB 6 verschiedene Trigger-Arten.
Gruß
Hansa
  Mit Zitat antworten Zitat
wlfmario

Registriert seit: 5. Jan 2005
Ort: Pulheim
115 Beiträge
 
#19

Re: Insert Generator bei Interbase klappt nicht !

  Alt 23. Jan 2006, 23:10
Ich kann mich täuschen aber irgend jemand hat mir mal gesagt das ich aus irgend einen Grund die Finger von der IBQuerry lasen soll.
Wieso das so war kann ich nicht mehr sagen, das war aber der Grund weshalb ich die nie verwendet habe.
Was mein Projekt betrifft, habe ich alle Formulare auf DBEdit umgestellt und die Daten werden jetzt mit Insert in die DB geschrieben, der Generator wir von den Komponenten verwaltet.

Nur leider ist es Schade, das ich nicht weis wieso ich mit den Insert Befehl keine Daten in die DB bekommen habe.
Mario
  Mit Zitat antworten Zitat
Hansa

Registriert seit: 9. Jun 2002
Ort: Saarland
7.554 Beiträge
 
Delphi 8 Professional
 
#20

Re: Insert Generator bei Interbase klappt nicht !

  Alt 23. Jan 2006, 23:47
Zitat von wlfmario:
Ich kann mich täuschen aber irgend jemand hat mir mal gesagt das ich aus irgend einen Grund die Finger von der IBQuery lasen soll.
Wahrscheinlich war das Borland, die die BDE eben nicht mehr weiterentwickeln. 8) Du brauchst nur TDataSet und basta. Mit dem Problem an sich hat das aber nichts zu tun. Außerdem driftet der Thread schwer ab. Geht der Generator oder nicht ? ID eintragen und "richtige" Daten sind zwei Paar Schuhe.
Gruß
Hansa
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 4     12 34      


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 16:58 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