AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Alter berechnen als Dezimalzahl mit SQL
Thema durchsuchen
Ansicht
Themen-Optionen

Alter berechnen als Dezimalzahl mit SQL

Ein Thema von RWarnecke · begonnen am 21. Apr 2012 · letzter Beitrag vom 22. Apr 2012
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von RWarnecke
RWarnecke

Registriert seit: 31. Dez 2004
Ort: Stuttgart
4.408 Beiträge
 
Delphi XE8 Enterprise
 
#1

Alter berechnen als Dezimalzahl mit SQL

  Alt 21. Apr 2012, 19:00
Hallo zusammen,

wie berechne ich über SQL das Alter in einer Dezimalzahl. Ein Beispiel :

Geburtsdatum : 29.08.1976
Ergebnis Alter : 35,64

Wie bekomme ich das in einem SQL-Befehl hin unter MySQL-Version: 5.1.61 ?

Mit diesem Befehl habe ich bis jetzt nur das volle Alter herausbekommen. Hier fehlen mir die Kommastellen.
Code:
SELECT FLOOR(PERIOD_DIFF(EXTRACT(YEAR_MONTH FROM NOW()), EXTRACT(YEAR_MONTH FROM BirthdayDate)) / 12)
Rolf Warnecke
App4Mission

Geändert von RWarnecke (22. Apr 2012 um 07:36 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von RWarnecke
RWarnecke

Registriert seit: 31. Dez 2004
Ort: Stuttgart
4.408 Beiträge
 
Delphi XE8 Enterprise
 
#2

AW: Alter berechnen als Dezimalzahl mit SQL

  Alt 21. Apr 2012, 19:20
Hallo zusammen,

habe soeben das Problem selber lösen können.

Lösung:
Code:
SELECT ROUND((UNIX_TIMESTAMP( NOW() )-UNIX_TIMESTAMP('1976-08-29 12:00:00'))/(60*60*24*365.2425), 2) as 'ALTER'
Rolf Warnecke
App4Mission
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#3

AW: Alter berechnen als Dezimalzahl mit SQL

  Alt 21. Apr 2012, 19:21
Floor() rundet ja auch ab.
Markus Kinzler
  Mit Zitat antworten Zitat
Iwo Asnet

Registriert seit: 11. Jun 2011
313 Beiträge
 
#4

AW: Alter berechnen als Dezimalzahl mit SQL

  Alt 22. Apr 2012, 00:13
Kann man nicht einfach CAST, CONVERT o.ä. verwenden?
  Mit Zitat antworten Zitat
Benutzerbild von RWarnecke
RWarnecke

Registriert seit: 31. Dez 2004
Ort: Stuttgart
4.408 Beiträge
 
Delphi XE8 Enterprise
 
#5

AW: Alter berechnen als Dezimalzahl mit SQL

  Alt 22. Apr 2012, 07:35
Wenn ich folgendes schreibe :
Code:
SELECT CAST(CURRENT_DATE() AS INTEGER);
Dann hat er ein Problem mit dem "AS INTEGER". Das gleiche passiert auch beim Convert.

Wenn man aber statt FLOOR de Befehl ROUND in den SQL-Befehl aus dem Beitrag #1 einsetzt, bekommt man das gleiche Ergebnis wie aus Beitrag #2.
Rolf Warnecke
App4Mission
  Mit Zitat antworten Zitat
Iwo Asnet

Registriert seit: 11. Jun 2011
313 Beiträge
 
#6

AW: Alter berechnen als Dezimalzahl mit SQL

  Alt 22. Apr 2012, 09:50
Ich würde ja auch nach FLOAT casten. Ich weiss nicht, ob das Standard ist, aber i.a. wird das Datum intern als Fließkommazahl dargestellt, die die Anzahl der Tage seit einem bestimmten Datum (1.1.1900 z.B.) angibt. Der Nachkommaanteil gibt die Zeit an, wobei 0,5 Uhr Mittags ist.

Die Differenz ist dann das Alter in Tagen.

Geändert von Iwo Asnet (22. Apr 2012 um 10:05 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#7

AW: Alter berechnen als Dezimalzahl mit SQL

  Alt 22. Apr 2012, 09:55
Und wenn es wirklich genau und somit aussagefähig sein soll, bräuchte man streng genommen auch noch mindestens die Geburtsstunde und könnte keinen festen Faktor zur Berücksichtigung der Schaltjahre verwenden, sondern müsste deren tatsächliche Anzahl im ermittelten Zeitraum bestimmen
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Iwo Asnet

Registriert seit: 11. Jun 2011
313 Beiträge
 
#8

AW: Alter berechnen als Dezimalzahl mit SQL

  Alt 22. Apr 2012, 10:06
Sowie den Geburtsort und den Ort, an dem die Frage nach dem Alter gestellt wird.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#9

AW: Alter berechnen als Dezimalzahl mit SQL

  Alt 22. Apr 2012, 10:16
Und die Schuhgröße der Hebamme (nun aber genug OT).
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
omata

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

AW: Alter berechnen als Dezimalzahl mit SQL

  Alt 22. Apr 2012, 11:00
Das Thema hatten wir hier ja schonmal.

Edit: Mit 365.2425 wird es nicht immer das richtige Ergebnis liefern.

Edit2: In MySQL gibt es doch DATEDIFF?
SELECT FLOOR(DATEDIFF(now(), geburtstag) / 365)

Edit3:
Ups, ich hatte folgendes überlesen...
Hier fehlen mir die Kommastellen.
Also einfach überlesen, was ich geschrieben haben. Sorry

Geändert von omata (22. Apr 2012 um 11:24 Uhr)
  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 21:12 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