AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Formate in SQL ändern
Thema durchsuchen
Ansicht
Themen-Optionen

Formate in SQL ändern

Ein Thema von Klaus D. · begonnen am 6. Dez 2005 · letzter Beitrag vom 12. Dez 2005
Antwort Antwort
Seite 1 von 3  1 23      
Klaus D.

Registriert seit: 27. Okt 2003
Ort: 03238 Finsterwalde
124 Beiträge
 
Delphi 6 Professional
 
#1

Formate in SQL ändern

  Alt 6. Dez 2005, 20:08
Datenbank: ADS • Version: 6.2 • Zugriff über: SQL
Hallo
Ich habe folgenden SQL String.
SQL-Code:
SELECT DA.id_daten
     , DA.titel
     , DA.filmlaenge
     , DA.isbn
     , DA.erstellt
     , DA.geaendert
     , DA.sid_Genre
     , DA.sid_Format
     , DA.sid_verliehen
     , DA.verliehen_Vorname
     , DA.verliehen_Name
     , DA.verliehen_PLZ
     , DA.verliehen_Ort
     , DA.verliehen_Tel
     , DA.verliehen_am
     , FA.id_format
     , FA.format
     , GR.id_genre
     , GR.genre
     , WG.name
     , WG.id_verliehen

FROM tbl_daten DA

LEFT OUTER JOIN tbl_format FA
ON (DA.sid_format=FA.id_Format)

LEFT OUTER JOIN tbl_genre GR
ON (DA.sid_genre=GR.id_Genre)

LEFT OUTER JOIN tbl_weg WG
ON (DA.sid_verliehen=WG.id_verliehen)




WHERE ((UPPER(DA.titel) like :p1) OR
       (UPPER(DA.filmlaenge) like :p1) OR
       (UPPER(DA.isbn) like :p1) OR
       (UPPER(DA.verliehen_Vorname) like :p1) OR
       (UPPER(DA.verliehen_am) like :p1) OR
       (UPPER(FA.format) like :p1) OR
       (UPPER(GR.Genre) like :p1))

order by DA.Titel ASC
Mein Problem ist, das "DA.verliehen am" als Date gespeichert ist.der Rest sind alles Stringfelder.
wie kann ich in meinem SQL-Sring dieses Feld in meine Suchfunktion einbeziehen?
MfG...Klaus
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#2

Re: Formate in SQL ändern

  Alt 6. Dez 2005, 20:27
Hallo Klaus,

du musst Felder, die keine String-Felder sind, per CAST() in einen String umwandeln bevor du sie mit LIKE untersuchen kannst.

Grüße vom marabu
  Mit Zitat antworten Zitat
Klaus D.

Registriert seit: 27. Okt 2003
Ort: 03238 Finsterwalde
124 Beiträge
 
Delphi 6 Professional
 
#3

Re: Formate in SQL ändern

  Alt 6. Dez 2005, 21:10
Es wäre nett wenn sie mir zeigen würden wie ich es wo in meinem String einbinde.
Danke
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#4

Re: Formate in SQL ändern

  Alt 6. Dez 2005, 21:22
Die übliche Syntax ist:

SELECT CAST(Da.verliehen_am AS VARCHAR(10)) AS verliehen_am FROM ... In diesem Forum duzen sich alle...

Freundliche Grüße vom marabu
  Mit Zitat antworten Zitat
Klaus D.

Registriert seit: 27. Okt 2003
Ort: 03238 Finsterwalde
124 Beiträge
 
Delphi 6 Professional
 
#5

Re: Formate in SQL ändern

  Alt 6. Dez 2005, 21:33
Mein ADS scheint mit CAST ein Problem zu haben.
folgende Fehlermeldung:
Fehlermeldung
Danke für dein Bemühen.
Mfg...Klaus
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#6

Re: Formate in SQL ändern

  Alt 6. Dez 2005, 21:45
Das sieht mir eher nach einem groben Syntaxfehler aus. Vielleicht hätte ich dir genauer schreiben sollen, wie du es angehen musst. Ersetze diese Zeile:

 (UPPER(DA.verliehen_am) like :p1) OR durch hier diese Zeile:

 (CAST(DA.verliehen_am AS VARCHAR(10)) like :p1) OR Dann sollte es funktionieren.

marabu

edit: 1 und lowercase(L) in :p1 verwechselt...
  Mit Zitat antworten Zitat
Klaus D.

Registriert seit: 27. Okt 2003
Ort: 03238 Finsterwalde
124 Beiträge
 
Delphi 6 Professional
 
#7

Re: Formate in SQL ändern

  Alt 6. Dez 2005, 21:56
Das selbe in Grün.
Ich werde Morgen ein wenig meine Bücher durchkämpfen und mich bei Gelegenheit noch mal melden.
Danke Klaus
  Mit Zitat antworten Zitat
Klaus D.

Registriert seit: 27. Okt 2003
Ort: 03238 Finsterwalde
124 Beiträge
 
Delphi 6 Professional
 
#8

Re: Formate in SQL ändern

  Alt 7. Dez 2005, 19:48
Hallo
So ich noch mal...ich komme nicht weiter.
Es scheint was mit der Formatierung des Strings zu tun zu haben.
HILFE !!!!!!
MfG...Klaus
  Mit Zitat antworten Zitat
alzaimar
(Moderator)

Registriert seit: 6. Mai 2005
Ort: Berlin
4.956 Beiträge
 
Delphi 2007 Enterprise
 
#9

Re: Formate in SQL ändern

  Alt 7. Dez 2005, 19:59
Ich kenne ADS nicht, aber vergleicht man daten nicht mit 'BETWEEN'?
Ich mache es immer so:
Select * from MyTable Where MyDateTimeColumn Between :Date and :DateNextDay Von Delphi aus:
Delphi-Quellcode:
...
  MyQuery.Params.ParamValues['Date'] := MyDate;
  MyQuery.Params.ParamValues['DateNextDay'] := MyDate+3599/3600; // also nicht ganz + 1 Tag, sondern +23:59
...
'Between' hat den Vorteil, das ein eventueller Index voll zur Geltung kommt. Nur die besten Optimierer erkennen bei einem Cast auf ein VarChar und eine Filterung per 'LIKE', das ein Index verwendet werden kann. Between dagegen ist hier optimal.
"Wenn ist das Nunstruck git und Slotermeyer? Ja! Beiherhund das Oder die Flipperwaldt gersput!"
(Monty Python "Joke Warefare")
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#10

Re: Formate in SQL ändern

  Alt 7. Dez 2005, 20:03
Zitat von Klaus D.:
Es scheint was mit der Formatierung des Strings zu tun zu haben.
Welche Formatierung von welchem String?

marabu
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23      


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 08:31 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