AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Firebird - Wochentage als String
Thema durchsuchen
Ansicht
Themen-Optionen

Firebird - Wochentage als String

Ein Thema von Neutral General · begonnen am 28. Dez 2009 · letzter Beitrag vom 28. Dez 2009
Antwort Antwort
Benutzerbild von Neutral General
Neutral General

Registriert seit: 16. Jan 2004
Ort: Bendorf
5.219 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#1

Firebird - Wochentage als String

  Alt 28. Dez 2009, 18:47
Datenbank: Firebird • Version: 2.1 • Zugriff über: unwichtig (IB Expert)
Hi,

Also ich weiß nicht ob folgendes möglich ist. Ich habe ein Integer-Feld. Und ich möchte wenn ich es selektiere nicht 1-7 erhalten, sondern "Montag" bis "Sonntag". Ich dachte an soetwas wie

SQL-Code:
SELECT
  tab.wochentag AS INDEX OF ("Montag","Dienstag","Mittwoch","Donnerstag","Freitag","Samstag","Sonntag")
FROM tab
Ist natürlich Syntaktisch Schwachsinn
Aber gibt es da eine Möglichkeit?

Gruß
Neutral General
Michael
"Programmers talk about software development on weekends, vacations, and over meals not because they lack imagination,
but because their imagination reveals worlds that others cannot see."
  Mit Zitat antworten Zitat
Benutzerbild von mirage228
mirage228

Registriert seit: 23. Mär 2003
Ort: Münster
3.750 Beiträge
 
Delphi 2010 Professional
 
#2

Re: Firebird - Wochentage als String

  Alt 28. Dez 2009, 18:51
Mach ne zweite Tabelle "wochentage" wo du für die Schlüssel 1 bis 7 die Wochentagsnamen hinterlegst. Nun kannst Du über diese Tabelle joinen...
David F.

May the source be with you, stranger.
PHP Inspection Unit (Delphi-Unit zum Analysieren von PHP Code)
  Mit Zitat antworten Zitat
omata

Registriert seit: 26. Aug 2004
Ort: Nebel auf Amrum
3.154 Beiträge
 
Delphi 7 Enterprise
 
#3

Re: Firebird - Wochentage als String

  Alt 28. Dez 2009, 18:55
Eine zusätzliche Tabelle wäre auf jeden Fall sinnvoller.

Aber es geht auch folgendes...
SQL-Code:
SELECT CASE tab.wochentag
         WHEN 1 THEN 'Montag'
         WHEN 2 THEN 'Dienstag'
         WHEN 3 THEN 'Mittwoch'
         WHEN 4 THEN 'Donnerstag'
         WHEN 5 THEN 'Freitag'
         WHEN 6 THEN 'Samstag'
         WHEN 7 THEN 'Sonntag'
       END tag_text
FROM tab
  Mit Zitat antworten Zitat
Benutzerbild von Neutral General
Neutral General

Registriert seit: 16. Jan 2004
Ort: Bendorf
5.219 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#4

Re: Firebird - Wochentage als String

  Alt 28. Dez 2009, 18:57
Stimmt, dann könnte man sich die Strings dazujoinen.. Aber lohnt sich da der Aufwand für eine eigene Tabelle?
Michael
"Programmers talk about software development on weekends, vacations, and over meals not because they lack imagination,
but because their imagination reveals worlds that others cannot see."
  Mit Zitat antworten Zitat
Benutzerbild von mirage228
mirage228

Registriert seit: 23. Mär 2003
Ort: Münster
3.750 Beiträge
 
Delphi 2010 Professional
 
#5

Re: Firebird - Wochentage als String

  Alt 28. Dez 2009, 19:02
Zitat von Neutral General:
Stimmt, dann könnte man sich die Strings dazujoinen.. Aber lohnt sich da der Aufwand für eine eigene Tabelle?
Also es wäre zumindest sauberer meiner Meinung nach, so wären die Wochentage ja fest in die DFM einkodiert als Eigenschaft des SQL.Text der Query-Komponente (oder zumindest direkt im Quellcode). Wenn es aber nur dieser eine Fall ist, wäre das CASE-Statement (kannte ich z.B. noch gar nicht) vielleicht doch okay, aber mit einer eigenen Tabelle würdest Du unnötige Redundanzen vermeiden...
David F.

May the source be with you, stranger.
PHP Inspection Unit (Delphi-Unit zum Analysieren von PHP Code)
  Mit Zitat antworten Zitat
schlecki

Registriert seit: 11. Apr 2005
Ort: Darmstadt
148 Beiträge
 
Delphi XE2 Enterprise
 
#6

Re: Firebird - Wochentage als String

  Alt 28. Dez 2009, 21:59
Eine Tabelle wäre auch sinnvoller, wenn deine Anwendung später lokalisiert werden soll. Dann kann man die Tabelle entsprechend erweitern, sodass diese für alle unterstützten Sprachen die Wochentage liefern kann.

SQL-Code:
tag lang_id value
==================
1 de Montag
1 en Monday
2 de Dienstag
...
  Mit Zitat antworten Zitat
Benutzerbild von Neutral General
Neutral General

Registriert seit: 16. Jan 2004
Ort: Bendorf
5.219 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#7

Re: Firebird - Wochentage als String

  Alt 28. Dez 2009, 23:03
Zitat von schlecki:
Eine Tabelle wäre auch sinnvoller, wenn deine Anwendung später lokalisiert werden soll. Dann kann man die Tabelle entsprechend erweitern, sodass diese für alle unterstützten Sprachen die Wochentage liefern kann.

SQL-Code:
tag lang_id value
==================
1 de Montag
1 en Monday
2 de Dienstag
...
Keine Sorge, es ist nur ein kleines Miniprogramm für nen Freund und der spricht und liest in erster Linie Deutsch
Michael
"Programmers talk about software development on weekends, vacations, and over meals not because they lack imagination,
but because their imagination reveals worlds that others cannot see."
  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 09:07 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