AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Int-Feld nachträglich auf autoincrement setzen
Thema durchsuchen
Ansicht
Themen-Optionen

Int-Feld nachträglich auf autoincrement setzen

Ein Thema von messie · begonnen am 17. Sep 2012 · letzter Beitrag vom 19. Sep 2012
Antwort Antwort
Seite 1 von 2  1 2      
messie

Registriert seit: 2. Mär 2005
Ort: Göttingen
1.592 Beiträge
 
Delphi 2009 Professional
 
#1

Int-Feld nachträglich auf autoincrement setzen

  Alt 17. Sep 2012, 17:02
Datenbank: Firebird • Version: 2 • Zugriff über: FlameRobin
Moin,

ich möchte ein int-Feld (ID) in einer Tabelle nachträglich auf Autoincrement setzen und mache das mit dem FlameRobin-Dialog. Dort kann ich einen Generator erzeugen oder auswählen und einen Trigger erzeugen. Das sieht alles richtig aus, wenn ich Daten übergebe schlägt es aber fehl:
Code:
insert into MEASURED_DATA values (ID,1,2,3,4)
Klappt das nachträgliche Ändern nicht oder passt meine Übergabe nicht? Wenn ich die Autoincrement-Spalte weglasse, bekomme ich ein mismatch beim parametercount.

Grüße, Messie
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.314 Beiträge
 
Delphi 12 Athens
 
#2

AW: Int-Feld nachträglich auf autoincrement setzen

  Alt 17. Sep 2012, 17:09
Du solltest die Namen der Felder mit angeben, sonst weiß ja keiner was wo rein soll

[add]
www.w3schools.com/sql/sql_insert.asp
http://www.firebirdsql.org/refdocs/l...21-insert.html
Ein Therapeut entspricht 1024 Gigapeut.
  Mit Zitat antworten Zitat
Namenloser

Registriert seit: 7. Jun 2006
Ort: Karlsruhe
3.724 Beiträge
 
FreePascal / Lazarus
 
#3

AW: Int-Feld nachträglich auf autoincrement setzen

  Alt 17. Sep 2012, 17:09
Du musst in dem Fall die Spalten explizit angeben:

Code:
insert into MEASURED_DATA (spalte_a, spalte_b, spalte_c, spalte_d) values (1,2,3,4)
  Mit Zitat antworten Zitat
messie

Registriert seit: 2. Mär 2005
Ort: Göttingen
1.592 Beiträge
 
Delphi 2009 Professional
 
#4

AW: Int-Feld nachträglich auf autoincrement setzen

  Alt 17. Sep 2012, 17:23
Moin,

klappt so, danke!
Ich kann aber tatsächlich
Code:
insert into MEASURED_DATA values (35,1,2,3,4)
die Einträge auch ohne Bezeichner erzeugen, dabei wird dann aber wohl die autoincrement-Variable überschrieben.
Wahrscheinlich schreibt außer mir niemand immer die ganze Zeile
Ist eben ein Umbau eines Programms von Dateien auf Datenbank. Und da habe ich die ganze Zeile halt da...

Grüße, Messie
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.314 Beiträge
 
Delphi 12 Athens
 
#5

AW: Int-Feld nachträglich auf autoincrement setzen

  Alt 17. Sep 2012, 17:27
Es wird nicht nur das Autoinc überschrieben (es wird gesetzt und nicht automatisch bestimmt), sondern rate mal was passiert, wenn sich mal das Datenbankschema ändert und die Felder in einer anderen Reihenfolge vorliegen.

Vielleicht ist es keine schlechte Idee immer die Feldnamen anzugeben.
Ein Therapeut entspricht 1024 Gigapeut.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

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

AW: Int-Feld nachträglich auf autoincrement setzen

  Alt 17. Sep 2012, 17:40
Ob der "AutoInc"-Wert überschrieben wird, hängt davon ab, wie der zugehörige Trigger aussieht
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.867 Beiträge
 
Delphi 11 Alexandria
 
#7

AW: Int-Feld nachträglich auf autoincrement setzen

  Alt 17. Sep 2012, 17:41
Zudem muss man den Initialwert anpassen, sonst gibt es eine Kollision
Markus Kinzler
  Mit Zitat antworten Zitat
messie

Registriert seit: 2. Mär 2005
Ort: Göttingen
1.592 Beiträge
 
Delphi 2009 Professional
 
#8

AW: Int-Feld nachträglich auf autoincrement setzen

  Alt 18. Sep 2012, 16:13
Ob der "AutoInc"-Wert überschrieben wird, hängt davon ab, wie der zugehörige Trigger aussieht
Moin,

das wüsste ich gerne mal genauer. Ich habe für das Inkrementieren einen Generator und einen Trigger. Ich hätte vom Bezeichner her gedacht, dass hinter dem Generator die Prozedur zur Berechnung des nächsten Index steht. Der ist aber leer, dafür finde ich das im Trigger. Ist der Generator nur eine Variable oder ein Flag, die auf den Trigger verweisen? Dann bräuchte man den doch gar nicht.

Grüße, Messie

wie immer schon mal vorab sorry für die dämlichen Fragen
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#9

AW: Int-Feld nachträglich auf autoincrement setzen

  Alt 17. Sep 2012, 18:12
Wahrscheinlich schreibt außer mir niemand immer die ganze Zeile
Bei einem INSERT wird immer eine ganze Zeile geschrieben!
Dabei muss man insbesondere die AutoInc-Felder weglassen, denn diese Felder werden ja autom. vom DBMS bzw. vom Trigger befüllt.

Das Blöde an AutoInc-Feldern ist dass man den vergebenen Wert im Nachhinein nur schwer feststellen kann.
Solange dein Programm den neuen AutoInc-Wert nach dem Insert nicht benötigt ist das aber ok.
Beim SQL-Server kann man den letzten Wert mit SELECT @@Identity abfragen; aber das ist Gemurkse.
Andreas
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Int-Feld nachträglich auf autoincrement setzen

  Alt 17. Sep 2012, 18:16
Das gilt so nicht für FireBird, denn hier wird der AutoInc über einen Generator(Sequenz) und einen Trigger implementiert.
Markus Kinzler
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 01:55 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz