AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi MS-SQL letzter Datensatz
Thema durchsuchen
Ansicht
Themen-Optionen

MS-SQL letzter Datensatz

Ein Thema von Peeters · begonnen am 29. Okt 2004 · letzter Beitrag vom 29. Okt 2004
Antwort Antwort
Seite 1 von 2  1 2      
Peeters

Registriert seit: 3. Dez 2002
Ort: Meerbusch
86 Beiträge
 
Delphi 2007 Enterprise
 
#1

MS-SQL letzter Datensatz

  Alt 29. Okt 2004, 17:08
Hallo,

wie kann ich nach einen SQL-Execute, die letzte automatisch hochgezählte Nr. von einen Datensatz herrausbekommen?

Bei meiner alten Datenbank(ADS) ging das mit "LastAutoincVal".

Vielen Dank im voraus.
Peeters
  Mit Zitat antworten Zitat
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#2

Re: MS-SQL letzter Datensatz

  Alt 29. Okt 2004, 17:18
Was für ein SQL-Execute... Rufst du eine SP auf, oder schreibst du was direkt in eine Tabelle mittels insert.

Vielleicht meinst du das:
SELECT @@IDENTITY AS 'Identity' Gruß
  Mit Zitat antworten Zitat
Peeters

Registriert seit: 3. Dez 2002
Ort: Meerbusch
86 Beiträge
 
Delphi 2007 Enterprise
 
#3

Re: MS-SQL letzter Datensatz

  Alt 29. Okt 2004, 18:04
Zitat von Jelly:
Was für ein SQL-Execute... Rufst du eine SP auf, oder schreibst du was direkt in eine Tabelle mittels insert.
Ich übergebe den SQL-String an ADOCommand. Und möchte nun den Wert aus dem Feld "NrLFN" auslesen/erfragen, da in diesen Feld der Wert durch den SQL-Server automatisch erhöht wird. Wie mach ich das?

Gruß
Peeters
  Mit Zitat antworten Zitat
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#4

Re: MS-SQL letzter Datensatz

  Alt 29. Okt 2004, 18:16
Hallo,

eigentlich würd mich mal dein SQL String interessieren. Was soll ich so sagen
  Mit Zitat antworten Zitat
Peeters

Registriert seit: 3. Dez 2002
Ort: Meerbusch
86 Beiträge
 
Delphi 2007 Enterprise
 
#5

Re: MS-SQL letzter Datensatz

  Alt 29. Okt 2004, 20:17
CommandText := 'INSERT INTO WG (WGNR, WGBEZ, CREATETIME, CREATENAME, WGDELETE) VALUES ('+ QuotedStr(EditWGNr.Text) +', '+ QuotedStr(DBEditWGBez.Text) +', '+ Quotedstr(DateTimeToStr(now)) +', '+ QuotedStr(ccfg.benutzer) +', 0)'; und das Feld welches automatisch hoch zählt lautet "WGNRLFN", Typ "Int".

Gruß
Peeters
  Mit Zitat antworten Zitat
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#6

Re: MS-SQL letzter Datensatz

  Alt 29. Okt 2004, 20:20
OK, jetzt hab ichs gerafft...

Dann hast du eigentlich schon meine Antwort... Ein

SELECT @@IDENTITY AS 'Identity'

liefert dir nach dem Einfügen den aktuellen Wert
  Mit Zitat antworten Zitat
Peeters

Registriert seit: 3. Dez 2002
Ort: Meerbusch
86 Beiträge
 
Delphi 2007 Enterprise
 
#7

Re: MS-SQL letzter Datensatz

  Alt 29. Okt 2004, 20:31
Jo, danke ich bin noch nicht lange bei MS-SQL dabei. Muss ich diese SELECT abfrage mit der normalen ADODataSet abfragen?
Peeters
  Mit Zitat antworten Zitat
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#8

Re: MS-SQL letzter Datensatz

  Alt 29. Okt 2004, 20:55
nimm ein 2. ADOQuery und schreib den SQL Befehl rein. Dann öffnest du die Datenmenge mit "Open" und liest die Spalte 'Identity' aus... Achte aber drauf, daß dein Insert Befehl und dein Auslesen in der gleichen Transaction abläuft.

Gruß,
Tom
  Mit Zitat antworten Zitat
Peeters

Registriert seit: 3. Dez 2002
Ort: Meerbusch
86 Beiträge
 
Delphi 2007 Enterprise
 
#9

Re: MS-SQL letzter Datensatz

  Alt 29. Okt 2004, 21:02
Und da liegt das nächste Problem. Wie mache ich dass mit der Tranaktion?
Peeters
  Mit Zitat antworten Zitat
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#10

Re: MS-SQL letzter Datensatz

  Alt 29. Okt 2004, 21:17
Ich schlag mal vor, du ziehst dir erst mal ne gehörige Portion Grundwissen rein. Nur so als Tip.

Du hast doch deine ADOQuery an einem TADOConnection hängen. Mit
ADOConnection1.begintrans ;

startest du die Transaction,

mit ADOConnection1.committrans ;

schliesst du sie ab.
  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 19:14 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