SQL Server-Umwandlungsfunktion

Sql Server Umwandlungsfunktion



„Ob Sie gerade erst anfangen oder ein erfahrener Entwickler sind, Sie werden auf Typumwandlung stoßen. Typkonvertierung bezieht sich auf den Prozess der Konvertierung eines Werts oder Ausdrucks von einem Datentyp in einen anderen kompatiblen Datentyp.

In diesem Beitrag werden wir die Verwendung der Funktion cast() in SQL Server erörtern, um einen Wert oder Ausdruck von einem Typ in einen anderen zu konvertieren.“







SQL Server-Umwandlungsfunktion

Das folgende Snippet zeigt die Syntax der Funktion cast().



GIESSEN ( Ausdruck WIE Datentyp [ ( LÄNGE ) ] )

Die Funktion akzeptiert die folgenden Parameter:



  1. Ausdruck – jeder gültige Ausdruck.
  2. data_type – legt den Zieldatentyp fest.
  3. length – ein optionaler ganzzahliger Wert, der als Länge des Zieldatentyps definiert ist (nur für unterstützte Typen).

Die Funktion gibt dann den in den Zieldatentyp umgewandelten Ausdruck zurück.





Lassen Sie uns anhand von Beispielen veranschaulichen, wie wir die Cast-Funktion verwenden können.

Verwenden der Cast-Funktion zum Konvertieren von Strings in Integer

Im folgenden Beispiel wird die Umwandlungsfunktion verwendet, um die Eingabezeichenfolge in einen ganzzahligen Wert zu konvertieren.



AUSWÄHLEN
GIESSEN ( '100' WIE INT ) WIE Ausgabewert;

Die resultierende Ausgabe:

Ausgabewert |
-------------+
100 |

Verwenden der Cast-Funktion zum Konvertieren von Decimal in Int

Das zweite Beispiel unten verwendet die Cast-Funktion, um einen dezimalen Typ in int umzuwandeln.

AUSWÄHLEN
GIESSEN ( 3.14159 WIE INT ) WIE Ausgabewert;

Die Cast-Funktion rundet die eingegebene Dezimalzahl wie gezeigt auf den nächsten ganzzahligen Wert:

Ausgabewert |
-------------+
3 |

Verwenden der Cast-Funktion zum Konvertieren von String in Datetime

Wir können auch die Cast-Funktion verwenden, um eine bestimmte Eingabezeichenfolge in einen Datetime-Wert umzuwandeln. Eine Beispielabbildung ist unten gezeigt:

AUSWÄHLEN
GIESSEN ( '2022-10-10' WIE Terminzeit ) WIE Ausgabewert;

Ergebnisausgabe:

Ausgabewert |
-----------------------+
2022 - 10 - 10 00:00: 00.000 |

Verwenden der Cast-Funktion für Tabellenspalten

Wir können die Cast-Funktion auch auf eine bestimmte Spalte anwenden und die Zeilen aus dieser Spalte in einen anderen Datentyp konvertieren.

Angenommen, wir haben eine Tabelle:

Wir können die Werte der Spalte size_on_disk wie gezeigt in Ganzzahlen umwandeln:

AUSWÄHLEN
Servername ,
GIESSEN ( size_on_disk WIE INT ) WIE appx_size
AUS
Einträge;

Die resultierende Tabelle sieht wie folgt aus:

Wie wir sehen können, wird die resultierende Ausgabe als ganzzahlige Werte (gerundet) ausgedrückt.

HINWEIS: Es ist gut zu bedenken, dass es verschiedene Konvertierungstypen gibt.

  1. Implizite Konvertierung – Die SQL Server-Engine wendet automatisch die Konvertierungsoperation an, die der angeforderten Operation am besten entspricht.
  2. Explizite Konvertierung – manuell vom Benutzer durch Aufrufen von Konvertierungsfunktionen wie cast() und convert() durchgeführt.

Das folgende Diagramm zeigt, welche Typen Sie konvertieren können, welche Art von Konvertierung angewendet wird und mehr.

Quelle: Microsoft

Einschießen

Vielen Dank für das Lesen dieses Tutorials. Wir vertrauen darauf, dass Sie aus diesem Leitfaden etwas Neues gelernt haben.