Freigeben über


money und smallmoney (Transact-SQL)

Gilt für:SQL ServerAzure SQL-DatenbankAzure SQL Managed InstanceAzure Synapse AnalyticsAnalytics Platform System (PDW)SQL-Datenbank in Microsoft Fabric

Datentypen zur Darstellung von Währungswerten.

Bemerkungen

Datentyp Range Storage
money -922.337.203.685.477,5808 bis 922.337.203.685.477,5807 (-922.337.203.685.477,58
bis 922.337.203.685.477,58 für Informatica. Informatica unterstützt nur zwei Dezimalstellen, nicht vier.)
8 Bytes
smallmoney -214,748.3648 bis 214.748,3647 4 Bytes

Die Datentypen money und smallmoney weisen die Genauigkeit eines Zehntausendstels der dargestellten Währungseinheiten auf. Für Informatica weisen die Datentypen money und smallmoney die Genauigkeit eines Hundertstels der dargestellten Währungseinheiten auf.

Mit einem Punkt werden Währungsuntereinheiten, wie z. B. Cent, von ganzen Währungseinheiten getrennt. Gibt beispielsweise 2.15 2 Dollar und 15 Cent an.

Diese Datentypen können eines der folgenden Währungssymbole verwenden.

Symbol Währung Hexadezimalwert
$ Dollarzeichen 0024
¢ Cent-Zeichen 00A2
£ Pfundzeichen 00A3
¤ Währungssymbol 00A4
¥ Yen-Zeichen 00A5
Bengalische Rupienmarke 09F2
Bengali-Rupienzeichen 09F3
฿ Thai Baht Währungssymbol 0E3F
Khmer Riel Währungssymbol 17DB
Euro-Währungszeichen 20A0
Doppelpunktzeichen 20A1
Cruzeiro-Zeichen 20A2
Französisches Franczeichen 20A3
Lira-Zeichen 20A4
Millzeichen 20A5
Naira-Zeichen 20A6
Peseta-Zeichen 20A7
Rs Rupienzeichen 20A8
Won sign 20A9
Neues Sheqel-Zeichen 20AA
Dong-Zeichen 20AB
Eurozeichen 20AC
Kip-Zeichen 20AD
Tugrik-Zeichen 20AE
Drachmazeichen 20AF
Deutsches Centzeichen 20B0
Pesozeichen 20B1
Rialzeichen FDFC
Kleines Dollarzeichen FE69
Dollarzeichen voller Breite FF04
Cent-Zeichen mit voller Breite FFE0
Pfundzeichen voller Breite FFE1
Yenzeichen mit voller Breite FFE5
Zeichen "Won" mit voller Breite FFE6

Sie müssen keine Währungs- oder Währungsdaten in einfache Anführungszeichen (') einschließen. Sie können zwar Währungswerte vor einem Währungssymbol angeben, SQL Server speichert jedoch keine Währungsinformationen, die dem Symbol zugeordnet sind, und speichert nur den numerischen Wert.

Warnung

Beim Speichern von Geldwerten als Geld und Kleingeld können Sie Fehler durch Abschneiden runden. Vermeiden Sie die Verwendung dieses Datentyps, wenn Ihre Geld- oder Währungswerte in Berechnungen verwendet werden. Verwenden Sie stattdessen den Dezimaldatentyp mit mindestens vier Dezimalstellen.

Konvertieren von Gelddaten

Beim Konvertieren von Ganzzahldatentypen in money-Datentypen wird davon ausgegangen, dass es sich bei den Einheiten um Währungseinheiten handelt. Beispielsweise wird der ganzzahlige Wert von 4 4 Währungseinheiten in das Geldäquivalent konvertiert.

Das folgende Beispiel konvertiert smallmoney- und money-Werte jeweils in varchar- und decimal-Datentypen.

DECLARE @mymoney_sm SMALLMONEY = 3148.29,
    @mymoney MONEY = 3148.29;

SELECT CAST(@mymoney_sm AS VARCHAR(20)) AS 'SM_MONEY VARCHAR(20)',
    CAST(@mymoney AS DECIMAL) AS 'MONEY DECIMAL';

Hier sehen Sie das Ergebnis. Da der Dezimaltyp im Beispiel keine Skalierung aufweist, wird der Wert abgeschnitten.

SM_MONEY VARCHAR(20)           MONEY DECIMAL
------------------------------ ----------------------
3148.29                        3148