AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi SQL-Befehl vervollständigen?
Thema durchsuchen
Ansicht
Themen-Optionen

SQL-Befehl vervollständigen?

Ein Thema von AlexII · begonnen am 2. Jun 2014 · letzter Beitrag vom 2. Jun 2014
Antwort Antwort
AlexII

Registriert seit: 28. Apr 2008
1.717 Beiträge
 
FreePascal / Lazarus
 
#1

SQL-Befehl vervollständigen?

  Alt 2. Jun 2014, 19:26
Datenbank: SQLite • Version: 3 • Zugriff über: SQLiteSimpleDelphi-Wrapper
Hallo,

ich habe in meiner DB eine Spalte mit einem Datum. Nun möchte ich das Datum in eine andere Spalte "kopieren" und ein String dazu fügen.

ID | Datum | Datum2
1 | 1.1.14 | 1.1.14: Angelegt
2 | 4.6.14 | 4.6.14: Angelegt
...
7 | 7.7.14 | 7.7.14: Angelegt

Irgendwie klappt es bei mir nicht, hab bereits folgendes, aber ist wohl nicht ganz richtig.

Code:
UPDATE tabelle SET datum2 = (SELECT datum FROM tabelle WHERE id = i) + ': Angelegt' WHERE id = i
Und noch eine Frage wäre, wie kann ich i in einem SQL-Befehl hochzählen?
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!

Geändert von AlexII ( 2. Jun 2014 um 19:29 Uhr)
  Mit Zitat antworten Zitat
milchbrötchen

Registriert seit: 3. Apr 2007
Ort: Konstanz
36 Beiträge
 
#2

AW: SQL-Befehl vervollständigen?

  Alt 2. Jun 2014, 19:35
das sollte funktionieren:

Code:
UPDATE tabelle SET datum2 = concat(datum,': Angelegt') WHERE id = i
hochzählen in einer einzigen sql anweisung geht. entweder das where weglassen und das update für alle datensätze ausführen, oder ausgewählte ids gleichzeitig mit "where id in (1,2,7,9)"
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: SQL-Befehl vervollständigen?

  Alt 2. Jun 2014, 19:47
Jupp, das gleiche WHERE in der selben Tabelle hätte einem zeigen können, daß man sich das SubSelect sparen kann, da man bereits im selben Datensatz ist.

Noch eindeutiger wird es, wenn man das WHERE des SubSelects entsprechend anpasst.
SQL-Code:
UPDATE tabelle SET datum2 = (SELECT x.datum FROM tabelle AS x WHERE x.id = tabelle.id) + ': Angelegt--WHERE id = i

UPDATE tabelle SET datum2 = datum + ': Angelegt--WHERE id = i
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat
AlexII

Registriert seit: 28. Apr 2008
1.717 Beiträge
 
FreePascal / Lazarus
 
#4

AW: SQL-Befehl vervollständigen?

  Alt 2. Jun 2014, 19:50
Ok, aber was ist concat? Ich arbeite mit SQLite, das kennt wohl den Befehl nicht.

Code:
no such function: concat
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!
  Mit Zitat antworten Zitat
AlexII

Registriert seit: 28. Apr 2008
1.717 Beiträge
 
FreePascal / Lazarus
 
#5

AW: SQL-Befehl vervollständigen?

  Alt 2. Jun 2014, 19:56
UPDATE tabelle SET datum2 = datum + ': Angelegt'
Thx...

Komisch nur, dass mit
Code:
UPDATE tabelle SET datum2 = datum
das Datum vollständig kopiert wird, aber mit

Code:
UPDATE tabelle SET datum2 = datum + ': Angelegt'
nur der Tag und der Monat... der Rest fehlt.
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!
  Mit Zitat antworten Zitat
EarlyBird

Registriert seit: 29. Mär 2007
235 Beiträge
 
#6

AW: SQL-Befehl vervollständigen?

  Alt 2. Jun 2014, 20:44
Versuchs mal mit:
Code:
UPDATE tabelle SET datum2 = datum || ': Angelegt'
  Mit Zitat antworten Zitat
AlexII

Registriert seit: 28. Apr 2008
1.717 Beiträge
 
FreePascal / Lazarus
 
#7

AW: SQL-Befehl vervollständigen?

  Alt 2. Jun 2014, 21:00
Ja... es klappt, danke euch!
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: SQL-Befehl vervollständigen?

  Alt 2. Jun 2014, 21:41
Wobei ich das Feld nicht in die Datenbank schreiben würde (da redundant) sondern erts bei der Abfrage generieren würde.
Markus Kinzler
  Mit Zitat antworten Zitat
AlexII

Registriert seit: 28. Apr 2008
1.717 Beiträge
 
FreePascal / Lazarus
 
#9

AW: SQL-Befehl vervollständigen?

  Alt 2. Jun 2014, 22:10
Wobei ich das Feld nicht in die Datenbank schreiben würde (da redundant) sondern erts bei der Abfrage generieren würde.
Es ging mir eigentlich nur um SQL. Sonst wäre es natürlich richtig.
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!
  Mit Zitat antworten Zitat
Antwort Antwort


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 03:03 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