AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Felder in SQL-Abfrage mit Prefix (Tabellenname) benennen
Thema durchsuchen
Ansicht
Themen-Optionen

Felder in SQL-Abfrage mit Prefix (Tabellenname) benennen

Ein Thema von BlueStarHH · begonnen am 12. Dez 2023 · letzter Beitrag vom 13. Dez 2023
Antwort Antwort
BlueStarHH

Registriert seit: 28. Mär 2005
Ort: Hamburg
850 Beiträge
 
Delphi 11 Alexandria
 
#1

Felder in SQL-Abfrage mit Prefix (Tabellenname) benennen

  Alt 12. Dez 2023, 20:26
Datenbank: Firebird • Version: 3.x • Zugriff über: IBDAC
Hallo,

ich hab eine große Abfrage wie diese (alle Felder für einen kompletten Export):

Code:
select a.*, b.*, c.* from a
left join b on b.aid = a.id
left join c on c.aid = a.id
...
Es sind 5 Tabellen mit zusammen etwa 200 Feldern. Das Problem ist, dass es in meheren Tabellen Felder mit dem gleichen Namen gibt. So gibt es z.B. in der Tabelle a ein Feld das Zusatz1 und in der Tabelle b auch Zusatz1 heißt. Das zweite Feld wird im Abfragergebnis dann automatisch zu Zusatz1_1 umbenannt. Wie kann ich automatisch vor ALLE Felder den Tabellennamen setzen? Ich möchte also dass die beiden Felder dann z.B. a_Zusatz1 und b_Zusatz1 heißen. Oder auch nur a_EinFeldNurInA. Immer wenn neue Felder hinzukommen, möchte ich das Script auch NICHT anpassen. Ist das möglich? Danke!
  Mit Zitat antworten Zitat
lxo

Registriert seit: 30. Nov 2017
288 Beiträge
 
Delphi 12 Athens
 
#2

AW: Felder in SQL-Abfrage mit Prefix (Tabellenname) benennen

  Alt 12. Dez 2023, 22:07
Mit Firebird direkt wüsste ich jetzt nicht, aber du könntest dir ja in Delphi den Select mit Hilfe der Firebird-Systemtabellen zusammenbasteln.
Mit der Tabelle RDB$RELATION_FIELDS solltest du alle Felder zu deiner Tabelle finden und dann kannst alle Felder einzeln mit einem definierten Alias zusammenfügen.
  Mit Zitat antworten Zitat
Benutzerbild von Jasocul
Jasocul

Registriert seit: 22. Sep 2004
Ort: Delmenhorst
1.355 Beiträge
 
Delphi 11 Alexandria
 
#3

AW: Felder in SQL-Abfrage mit Prefix (Tabellenname) benennen

  Alt 13. Dez 2023, 07:24
Wie kann ich automatisch vor ALLE Felder den Tabellennamen setzen? Ich möchte also dass die beiden Felder dann z.B. a_Zusatz1 und b_Zusatz1 heißen. Oder auch nur a_EinFeldNurInA. Immer wenn neue Felder hinzukommen, möchte ich das Script auch NICHT anpassen. Ist das möglich? Danke!
Mir ist keine Möglichkeit bekannt, das automatisch nach einem vorgegebenen Schema machen zu lassen. Üblicherweise wird das mit Feld-Aliasen gelöst. Da die DB aber eine Automatik hat (fortlaufender Zähler als Suffix am Feldnamen), kann man das vielleicht in den tiefen der DB-Routinen nachlesen. Allerdings habe ich Zweifel, dass man die Tabellen-Aliase dabei berücksichtigen kann. Eventuell kanns du ein kleines Programm schreiben, dass dir das Script passend umwandelt.
Um das Script nicht ständig anpassen zu müssen, bietet sich eine View an. Dann muss diese zwar angepasst werden, aber dafür hast du es an zentraler Stelle.
Peter
  Mit Zitat antworten Zitat
TigerLilly

Registriert seit: 24. Mai 2017
Ort: Wien, Österreich
1.211 Beiträge
 
Delphi 11 Alexandria
 
#4

AW: Felder in SQL-Abfrage mit Prefix (Tabellenname) benennen

  Alt 13. Dez 2023, 16:41
Die Frage ist vielleicht auch, was man mit 200 Feldern dann anfängt.

Du könntest dir das SQL Statement selbst erzeugen + dort alle Felder einzeln angeben samt Namen unter dem du das Feld dann ansprechen mnöchtest.
  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