AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Query soll anderen Datentyp liefern
Thema durchsuchen
Ansicht
Themen-Optionen

Query soll anderen Datentyp liefern

Ein Thema von Medium · begonnen am 2. Sep 2009 · letzter Beitrag vom 3. Sep 2009
Antwort Antwort
Seite 1 von 2  1 2      
Medium

Registriert seit: 23. Jan 2008
3.685 Beiträge
 
Delphi 2007 Enterprise
 
#1

Query soll anderen Datentyp liefern

  Alt 2. Sep 2009, 10:56
Datenbank: MySQL • Version: 4.1 • Zugriff über: Zeos
Moinmoin!

Ich bastel hier gerade ein älteres Projekt um, und stoße auf einen Stein. Ich hab hier einen schicken QuickReport (den ich auf keinen Fall nach Rave oder was-auch-immer umbauen werde, das zahlt mir keine Sau ). Der hängt an einer TZQuery, in deren SQL Statement u.a. ein gezähltes Feld vorkommt (COUNT(foo)). Nun meckert mich meine TQRExpr-Kompo die mit dessen Darstellung beauftragt ist an, dass dieses Feld einen unbekannten Datentyp hätte.
Kurzerhand die Felder im Feldeditor des Querys automatisch eingefügt, und erkannt: Es ist ein TLargeintField statt eines TIntegerFields, welches sich in einer anderen nicht berechneten Spalte auch ganz wunderbar darstellen lässt.
Ich möchte nun MySQL egal wie unsanft davon überzeugen, dass es mir auch in dem COUNT()-Feld gefälligst einen Int32, und keinen 64-Bitter zurückschmeisst. Mein erster Ansatz war CAST() oder CONVERT(), allerdings treffen die nur die Unterscheidung zwischen signed und unsigned, und machen ansonsten auch einen auf 64 Bit.

Wat habbich denn hier an Chancen und Möchlichkeiten?
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat
Benutzerbild von guinnes
guinnes

Registriert seit: 28. Feb 2007
Ort: Bottrop
265 Beiträge
 
Delphi 5 Enterprise
 
#2

Re: Query soll anderen Datentyp liefern

  Alt 2. Sep 2009, 12:32
Zitat von Medium:
Wat habbich denn hier an Chancen und Möchlichkeiten?
Multiplizier das berechnete Feld mit 1.0. Dann hast du zwar einen Floatwert, aber kein unbekanntes Format mehr
Glückauf
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.685 Beiträge
 
Delphi 2007 Enterprise
 
#3

Re: Query soll anderen Datentyp liefern

  Alt 2. Sep 2009, 12:39
Nach einiger Sucherei scheint es so zu sein, dass man da schlicht nix machen kann. Auch kann ich kein Update für QR runterladen, da ich dank Bündelung mit D7 keinen Zugang zu den Downloads habe - 1a. Darüber hinaus hab ich nichtmal rausgefunden welche QR Version wir nun eigentlich genau haben, und da ein Update vermutlich eh wieder nen kompletten Neuaufbau der Reports bedeutet hätte, hab ich mir nun anders beholfen:
Ich hab mir ne TkbMemTable geschnappt, der Felder mit den gewünschen Typen aufgezwängt, und die Records aus meinem TZQuery da rein gepresst. Die MemTable kann glücklicherweise als Source für einen QReport benutzt werden. Sicherlich nicht elegant, aber da die Tabellen nur ein paar zig bis ~200 Einträge haben verschmerzbarer als jede andere Alternative (welche als einzige mir erkenntliche eine komplette Migration der Reports auf Rave wäre, wo ich mir noch was intelligents zum Ersatz der TQRCharts hätte aus den Fingern saugen müssen).

Was einen so eine Popeligkeit doch an Zeit kosten kann

Sorry fürs so genervt klingen. 3h Schlaf und dann an sowas den Vormittag verheizen macht dünnhäutig =)

Edit: Huch! Hat sich einer zwischen gedrängelt. Gar keine so üble Idee guinnes, das versuch ich doch glatt auch noch! Merci!

Edit2: Tag gerettet, das klappt vorzüglich! Und fast schon peinlich dass ich da nicht selbst drauf kam, so simpel wie es ist. Ich schieb das mal auf meine kurze Nacht Danke dir guinnes!
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.685 Beiträge
 
Delphi 2007 Enterprise
 
#4

Re: Query soll anderen Datentyp liefern

  Alt 2. Sep 2009, 15:37
Ich muss das noch mal hoch ziehen, da sich eine sehr sehr ähnlich Frage ergeben hat:

Ich habe ja u.a. TQRCharts im Einsatz, und diese sollen auf ihrer X-Achse einen Datumswert tragen. Ziel ist ein Balkendiagramm, dass Werte tageweise summiert darstellt. Der SQL String schaut so aus:
SQL-Code:
SELECT DATE(V_DAT) AS V_DAT, ROUND(SUM(ANTEIL_I)) AS MENGE
FROM rpohis
WHERE CHARGE <= 100
  AND M_NR = '1
GROUP BY V_DAT
ORDER BY V_DAT
Das Feld V_DAT ist hier der Übeltäter, da es den Datumswert anders zurück liefert, als es die alte Version auf Basis von Paradox tat. Diese hat nämlich einen schmucken Float geliefert, den ich im Chart als Achsengröße einsetzen konnte. MySQL liefert hier aber einen String, und mit dem ist's dann leider Essig.

Nun steht in der MySQL Doku:
Zitat:
Note that if either operand is a floating-point value, the result is a floating-point value
Also ich, gewitzt wie ich bin, gleich mal den selben Trick wie oben probiert, und an DATE(V_DAT) noch ein *1.0 angehängt. Und leider Pustekuchen, ich bekomme lediglich das Jahr - also den Ganzzahlanteil daraus. Casts auf Datumstypen brachten auch nix, alle kommen als String in meiner ZQuery an. Auch ein +0.0 brachte übrigens selbiges Ergebnis.

Hat da evtl. noch jemand einen ähnlich einfachen aber genialen Kniff auf Lager, wie ich nun Datumswerte als Floats rauskitzeln kann?
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.195 Beiträge
 
Delphi 10.4 Sydney
 
#5

Re: Query soll anderen Datentyp liefern

  Alt 2. Sep 2009, 15:40
Zitat von Medium:
Auch kann ich kein Update für QR runterladen, da ich dank Bündelung mit D7 keinen Zugang zu den Downloads habe - 1a.
Du kannst dir ja eine QR-Lizenz kaufen um diese Bündelung aufzubrechen. Dann bekomst du auch ganz neue Versionen wo evtl. dein Problem gefixt ist.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.685 Beiträge
 
Delphi 2007 Enterprise
 
#6

Re: Query soll anderen Datentyp liefern

  Alt 2. Sep 2009, 15:51
Die 1000 Pfund lohnen sich für diese eine Migration nicht mehr für uns - es ist das letzte Projekt aus dem Altbestand "Paradox", und auch das einzige dass QR so intensiv nutzt. Da käme es glatt noch billiger alles auf Rave umzusetzen, und ich habe zudem nirgends einen Hinweis dazu gefunden dass o.g. Problem in neueren QR Versionen nicht mehr besteht. Über kurz oder lang wollten wir schon gerne weg von QR, und DANN mal eben vierstellig britisch dafür auf'n Tisch legen? Ich denke nicht

Das Eingangsproblem ist nun aber mit dem Kniff von guinnes zufriedenstellend gelöst, jetzt geht's nur noch um das von über deinem Posting.
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat
Benutzerbild von guinnes
guinnes

Registriert seit: 28. Feb 2007
Ort: Bottrop
265 Beiträge
 
Delphi 5 Enterprise
 
#7

Re: Query soll anderen Datentyp liefern

  Alt 2. Sep 2009, 16:08
Wenn dein V_DAT ein DateTime ist, liegts wohl an den Zeos, bei mir kommt ein Datetime Feld auch als Float rüber. Du könntest es noch mit UNIX_TIMESTAMP(V_DAT) versuchen und dann selber umrechnen.
Glückauf
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.685 Beiträge
 
Delphi 2007 Enterprise
 
#8

Re: Query soll anderen Datentyp liefern

  Alt 2. Sep 2009, 16:29
Es ist ein DATETIME (bzw. nur DATE nach dem DATE() Aufruf), allerdings bekomme ich die selben Ergebnisse im MySQL Explorer (der, der auf der MySQL Seite unter Tools mit angeboten wird). Ich vermute mal ganz forsch, dass die wohl eher nicht die Zeos benutzen.

Die Konvertierung auf diese Art ist mir vorhin garnicht aufgefallen, ich hatte immer mit CONVERT() rumexperimentiert. Das schaut glatt nach einer Möglichkeit aus, da ich nun aber zu Hause bin kann ich's erst morgen testen. Danke dir nochmals!
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat
Benutzerbild von guinnes
guinnes

Registriert seit: 28. Feb 2007
Ort: Bottrop
265 Beiträge
 
Delphi 5 Enterprise
 
#9

Re: Query soll anderen Datentyp liefern

  Alt 2. Sep 2009, 17:43
Hast du es mal ohne das DATE vorher versucht ?
Glückauf
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.685 Beiträge
 
Delphi 2007 Enterprise
 
#10

Re: Query soll anderen Datentyp liefern

  Alt 2. Sep 2009, 17:57
Das nicht direkt. Ich hatte in der Paradox-Variante ein CAST/SUBSTRING/CAST benutzt um das Datum um die Uhrzeit zu beschneiden, wo als letzter Schritt wieder auf DATETIME, also den Ursprungstyp, zurückgecastet wurde. Das hatte ich zunächst so übernommen, und das warf auch ein String hinten raus.
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 06:01 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