AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Datum als Parameter für MS-SQL-Server übergeben
Thema durchsuchen
Ansicht
Themen-Optionen

Datum als Parameter für MS-SQL-Server übergeben

Ein Thema von stefan681 · begonnen am 3. Feb 2009 · letzter Beitrag vom 3. Feb 2009
Antwort Antwort
stefan681

Registriert seit: 16. Jun 2005
18 Beiträge
 
#1

Datum als Parameter für MS-SQL-Server übergeben

  Alt 3. Feb 2009, 13:20
Datenbank: MS SQL Server • Version: 2008 • Zugriff über: ADO
Hallo,

ich habe folgendes Problem:

Ich möchte auf einen SQL-Server 2008 zugreifen über eine ADO-Query. Diese Query müsste ich auf einem Datumsbereich begrenzen:

'SELECT c001, c080 FROM Table WHERE c080 between :PVon and :PBis' Die Spalte c080 ist ein Datumswert.

So würde ich dann in Delphi weiter schreiben:

Delphi-Quellcode:
ADOQuery1.Parameter[0].Value := StrToDate('01.01.2009');
ADOQuery1.Parameter[1].Value := StrToDate('31.01.2009');
Wenn ich die Query Active setze, bekomme ich eine Fehlermeldung, das das Feature nicht implementiert ist.

In welchem Format müss ich das Datum angeben, damit der SQL-Server es versteht?

Vielen Dank.

Stefan
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#2

Re: Datum als Parameter für MS-SQL-Server übergeben

  Alt 3. Feb 2009, 13:30
Versuch's mal so:
SELECT c001, c080 FROM Table WHERE (c080 => :PVon) and (c080 < :PBis) und dann:
Delphi-Quellcode:
ADOQuery1.Parameters.ParamValues['PVon'] := StrToDate('01.01.2009');
ADOQuery1.Parameters.ParamValues['PBis'] := StrToDate('31.01.2009') + 1.0;
Hier gibt es zwei Dinge hervorzuheben:
* die Schreibweise .ParamValues[] drückt genau aus, welchen Parameter du befüllst
* die Abfrage liefert alle Datensätze zwischen 01.01.2009 0:00 Uhr bis 31.01.2009 23:59:59.999 Uhr
Der 31.01.2009 plus 1 Tag wäre ja der 01.02.2009 0:00Uhr; da die Bedinung aber auf "kleiner" lautet, ist der 1.2.2009 nicht eingeschlossen.

PS: das Feld c080 sollte natürlich den Datentyp "datetime" oder "smalldatetime" haben.
Andreas
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#3

Re: Datum als Parameter für MS-SQL-Server übergeben

  Alt 3. Feb 2009, 13:33
Hallo,

probiere mal bitte
Delphi-Quellcode:
ADOQuery1.Parameter[0].Value := '01.01.2009';
ADOQuery1.Parameter[1].Value := '31.01.2009';
  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 19: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