SQLite - Datentyp

Der SQLite-Datentyp ist ein Attribut, das den Datentyp eines Objekts angibt. Jede Spalte, Variable und jeder Ausdruck hat einen zugehörigen Datentyp in SQLite.

Sie würden diese Datentypen beim Erstellen Ihrer Tabellen verwenden. SQLite verwendet ein allgemeineres dynamisches Typsystem. In SQLite ist der Datentyp eines Werts dem Wert selbst zugeordnet, nicht seinem Container.

SQLite-Speicherklassen

Jeder in einer SQLite-Datenbank gespeicherte Wert verfügt über eine der folgenden Speicherklassen:

Sr.Nr. Speicherklasse & Beschreibung
1

NULL

Der Wert ist ein NULL-Wert.

2

INTEGER

Der Wert ist eine vorzeichenbehaftete Ganzzahl, die je nach Größe des Werts in 1, 2, 3, 4, 6 oder 8 Byte gespeichert wird.

3

REAL

Der Wert ist ein Gleitkommawert, der als 8-Byte-IEEE-Gleitkommazahl gespeichert wird.

4

TEXT

Der Wert ist eine Textzeichenfolge, die mithilfe der Datenbankcodierung (UTF-8, UTF-16BE oder UTF-16LE) gespeichert wird.

5

BLOB

Der Wert ist ein Datenblock, der genau so gespeichert wird, wie er eingegeben wurde.

Die SQLite-Speicherklasse ist etwas allgemeiner als ein Datentyp. Die INTEGER-Speicherklasse enthält beispielsweise 6 verschiedene ganzzahlige Datentypen unterschiedlicher Länge.

SQLite-Affinitätstyp

SQLite unterstützt das Konzept von type affinityauf Spalten. Jede Spalte kann weiterhin jeden Datentyp speichern, aber die bevorzugte Speicherklasse für eine Spalte heißt itsaffinity. Jeder Tabellenspalte in einer SQLite3-Datenbank wird eine der folgenden Typaffinitäten zugewiesen:

Sr.Nr. Affinität & Beschreibung
1

TEXT

In dieser Spalte werden alle Daten mit den Speicherklassen NULL, TEXT oder BLOB gespeichert.

2

NUMERIC

Diese Spalte kann Werte enthalten, die alle fünf Speicherklassen verwenden.

3

INTEGER

Verhält sich wie eine Spalte mit NUMERISCHER Affinität, mit Ausnahme eines CAST-Ausdrucks.

4

REAL

Verhält sich wie eine Spalte mit NUMERISCHER Affinität, außer dass sie ganzzahlige Werte in die Gleitkommadarstellung zwingt.

5

NONE

Eine Spalte mit der Affinität NONE bevorzugt keine Speicherklasse gegenüber einer anderen, und es wird kein Versuch unternommen, Daten von einer Speicherklasse in eine andere zu zwingen.

SQLite-Affinitäts- und Typnamen

In der folgenden Tabelle sind verschiedene Datentypnamen aufgeführt, die beim Erstellen von SQLite3-Tabellen mit der entsprechenden angewendeten Affinität verwendet werden können.

Datentyp Affinität
  • INT
  • INTEGER
  • TINYINT
  • SMALLINT
  • MEDIUMINT
  • BIGINT
  • UNSIGNED BIG INT
  • INT2
  • INT8
GANZE ZAHL
  • CHARACTER(20)
  • VARCHAR(255)
  • VERSCHIEDENER CHARAKTER (255)
  • NCHAR(55)
  • NATIVER CHARAKTER (70)
  • NVARCHAR(100)
  • TEXT
  • CLOB
TEXT
  • BLOB
  • Kein Datentyp angegeben
KEINER
  • REAL
  • DOUBLE
  • DOPPELTE GENAUIGKEIT
  • FLOAT
ECHT
  • NUMERIC
  • DECIMAL(10,5)
  • BOOLEAN
  • DATE
  • DATETIME
NUMERISCH

Boolescher Datentyp

SQLite verfügt nicht über eine separate boolesche Speicherklasse. Stattdessen werden Boolesche Werte als Ganzzahlen 0 (falsch) und 1 (wahr) gespeichert.

Datums- und Uhrzeitdatentyp

SQLite verfügt nicht über eine separate Speicherklasse zum Speichern von Datums- und / oder Uhrzeitangaben. SQLite kann jedoch Datums- und Uhrzeitangaben als TEXT-, REAL- oder INTEGER-Werte speichern.

Sr.Nr. Speicherklasse & Datumsformat
1

TEXT

Ein Datum in einem Format wie "JJJJ-MM-TT HH: MM: SS.SSS"

2

REAL

Die Anzahl der Tage seit Mittag in Greenwich am 24. November 4714 v

3

INTEGER

Die Anzahl der Sekunden seit 1970-01-01 00:00:00 UTC

Sie können Datums- und Uhrzeitangaben in einem dieser Formate speichern und mithilfe der integrierten Datums- und Uhrzeitfunktionen frei zwischen Formaten konvertieren.