„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > Wie kann ich das Alter in Jahren ab einem Geburtsdatum in SQL Server genau berechnen?

Wie kann ich das Alter in Jahren ab einem Geburtsdatum in SQL Server genau berechnen?

Gepostet am 2025-03-23
Durchsuche:191

How to Accurately Calculate Age in Years from a Date of Birth in SQL Server?

berechnen Sie das Alter des Geburtsdatums in SQL Server genau

Frage:

Wie kann das Geburtsdatum als nvarchar (25) in ein Datum in SQL Server umgewandelt und dann sein entsprechendes Alter in Jahren berechnet?

Beispieldaten:

AUSWEIS Name dob
1 John 1992-01-09 00:00:00
2 Ausfall 1959-05-20 00:00:00

erwartete Ausgabe:

]
AUSWEIS Name ALTER dob
1 John 31 1992-01-09 00:00:00
2 Ausfall 64 1959-05-20 00:00:00

Antwort: Berechnen Sie Age

] genau

Der ursprünglich vorgeschlagene Ansatz steht vor Herausforderungen bei der Prüfung der Unregelmäßigkeiten von Schaltjahren und Monaten. Moderne SQL -Serverversionen bieten uns verbesserte Techniken, um diese Komplexitäten zu beheben.

der beste Weg, um das Alter der Ganzzahlen zu berechnen:

Diese Methode ist einfach und unkompliziert, aber die Genauigkeit kann etwas niedriger sein als die Dezimalmethode.

SELECT
    (YEAR(GETDATE()) - YEAR(DOB)) - CASE WHEN MONTH(GETDATE()) 

der beste Weg, um das Alter der Dezimalstellen zu berechnen:

Diese Methode verwendet die Funktion datiff und die Aussage case , um das Alter genau zu berechnen und zu überlegen, ob der Geburtstag in diesem Jahr vergangen ist.

SELECT
    DATEDIFF(year, DOB, GETDATE()) - CASE WHEN MONTH(GETDATE()) 

Beachten Sie, dass der obige Code davon ausgeht, dass die Spalte dob in die date typisiert wurde. Wenn dob immer noch vom nvarchar (25) Typ ist, müssen Sie in der Abfrage eine Typ -Konvertierung hinzufügen, z. B. convert (Datum, dob, 120) . Die Auswahl des entsprechenden Konvertierungsstils hängt vom spezifischen Format Ihrer dob Daten ab. Zum Beispiel convert (Datum, Dob, 120) ist für das Format 'Yyyy-Mm-dd HH: Mi: SS' geeignet. Möglicherweise müssen Sie diesen Abschnitt an Ihr Datenformat anpassen. Die endgültige Abfrage sollte ähnlich sein wie:

SELECT
    DATEDIFF(year, CONVERT(DATE, DOB, 120), GETDATE()) - CASE WHEN MONTH(GETDATE()) 

ersetzen Sie yourTable mit Ihrem Tabellennamen. Die Methode zur Auswahl einer Ganzzahl oder Dezimalzahl hängt von Ihren Präzisionsanforderungen ab. Die Dezimalmethode ist genauer, aber die Ganzzahlmethode ist prägnanter.

Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3