Dies ist die alte 4D Dokumentations-Website. Die neue und aktualisierte Dokumentation finden Sie unter developer.4d.com |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
4D v20.6
TEXT TO BLOB
|
TEXT TO BLOB ( Text ; BLOB {; TextFormat {; Offset I *}} ) | ||||||||
Parameter | Typ | Beschreibung | ||||||
Text | String |
![]() |
Text zum Schreiben ins BLOB | |||||
BLOB | BLOB |
![]() |
BLOB zum Empfangen des Textes | |||||
TextFormat | Lange Ganzzahl |
![]() |
Format und Zeichensatz des Textes | |||||
Offset I * | Variable, Operator |
![]() |
Versatz im BLOB (in Bytes) oder * zum Anfügen des Wertes | |||||
![]() |
Ohne *: Neuer Versatz nach Schreiben in BLOB | |||||||
Der Befehl TEXT TO BLOB schreibt den Wert Text in BLOB.
Der Parameter TextFormat legt das interne Format und den Zeichensatz des zu schreibenden Textwertes fest. Übergeben Sie dazu eine der folgenden vordefinierten Konstanten unter dem Thema BLOB:
Konstante | Typ | Wert |
Mac C string | Lange Ganzzahl | 0 |
Mac Pascal string | Lange Ganzzahl | 1 |
Mac text with length | Lange Ganzzahl | 2 |
Mac text without length | Lange Ganzzahl | 3 |
UTF8 C string | Lange Ganzzahl | 4 |
UTF8 text with length | Lange Ganzzahl | 5 |
UTF8 text without length | Lange Ganzzahl | 6 |
Geben Sie den Parameter TextFormat nicht an, verwendet 4D standardmäßig das Format Mac C string. In Anwendungen, die mit 4D v11 erstellt wurden, arbeitet 4D standardmäßig mit dem Unicode Zeichensatz (UTF8) zur Textverwaltung, deshalb wird empfohlen, diesen Zeichensatz zu verwenden.
Hinweise:
Die verschiedenen Formate werden im folgenden beschrieben:
Textformat | Beschreibung und Beispiele |
C String | Der Text endet mit dem Zeichen NULL (ASCII Code $00) |
UTF8 | "" --> $00 |
"Café" --> $43 61 66 C3 A9 00 | |
Mac | "Café" --> $43 61 66 8E 00 |
Pascal String | Dem Text ist eine 1-Byte Länge vorangestellt |
UTF8 | - |
Mac | "" --> $00 |
"Café" --> $04 43 61 66 8E | |
Text mit Länge | Dem Text ist eine 4-Byte (UTF8) oder 2-Byte Länge (Mac) vorangestellt |
UTF8 | "" --> $00 00 00 00 |
"Café" --> $00 00 00 05 43 61 66 C3 A9 | |
Mac | "" --> $00 00 |
"Café" --> $00 04 43 61 66 8E | |
Text ohne Länge | Der Text besteht nur aus seinen Zeichen |
UTF8 | "" --> Kein Wert |
"Café" --> $43 61 66 C3 A9 | |
Mac | "" --> Kein Wert |
"Café" --> $43 61 66 8E |
Geben Sie den optionalen Parameter * an, wird der Wert vom Typ Zahl an das BLOB angefügt und die Größe des BLOB entsprechend erweitert. Mit dem optionalen Parameter * können Sie jede Zahl vom Typ Ganzzahl, Lange Ganzzahl, Zahl oder Text (siehe andere BLOB Befehle) sequentiell in einem BLOB speichern, solange der Speicher für das BLOB ausreicht.
Geben Sie den optionalen Parameter * oder den Parameter Offset nicht an, wird der Textwert am Anfang des BLOB gespeichert, der bisherige Inhalt wird überschrieben. Die Größe des BLOB wird entsprechend angepasst.
Übergeben Sie den Parameter Offset, wird der Textwert im BLOB am Byte-Versatz geschrieben (von Null ausgehend). Egal, wo Sie den Wert schreiben, die Größe des BLOB wird gemäß der übergebenen Position erhöht (bei Bedarf bis zur Größe des Textes). Neu zugewiesene Bytes, die Sie nicht schreiben, werden auf Null initialisiert.
Nach dem Aufruf wird die Variable Offset zurückgegeben, erhöht um die Anzahl der geschriebenen Bytes. Von daher können Sie dieselbe Variable mit einem anderen BLOB Befehl zum Schreiben eines anderen Wertes verwenden.
Kompatibilitätshinweis: Da dieser Befehl den als Parameter übergebenen Blob verändert, unterstützt er keine Blob-Objekte (Typ 4D.Blob). Siehe Übergabe von Blobs und Blob-Objekten an 4D Befehle auf developer.4d.com.
Nach Ausführen dieses Code:
SET BLOB SIZE(vxBlob;0)
C_TEXT(vtValue)
vtValue:="Café" ` Länge von vtValue ist 4 Bytes
TEXT TO BLOB(vtValue;vxBlob;Mac C string) ` BLOB Größe wird 5 Bytes
TEXT TO BLOB(vtValue;vxBlob;Mac Pascal string) ` BLOB Größe wird 5 Bytes
TEXT TO BLOB(vtValue;vxBlob;Mac text with length) ` BLOB Größe wird 6 Bytes
TEXT TO BLOB(vtValue;vxBlob;Mac text without length) ` BLOB Größe wird 4 Bytes
TEXT TO BLOB(vtValue;vxBlob;UTF8 C string) ` BLOB Größe wird 6 Bytes
TEXT TO BLOB(vtValue;vxBlob;UTF8 text with length) ` BLOB Größe wird 9 Bytes
TEXT TO BLOB(vtValue;vxBlob;UTF8 text without length) ` BLOB Größe wird 5 Bytes
BLOB to integer
BLOB to longint
BLOB to real
BLOB to text
CONVERT FROM TEXT
INTEGER TO BLOB
LONGINT TO BLOB
REAL TO BLOB
Produkt: 4D
Thema: BLOB
Nummer:
554
Geändert: 4D v11 SQL
Text, UTF8
4D Programmiersprache ( 4D v20)
4D Programmiersprache ( 4D v20.1)
4D Programmiersprache ( 4D v20.2)
4D Programmiersprache ( 4D v20.3)
4D Programmiersprache ( 4D v20.4)
4D Programmiersprache ( 4D v20.5)
4D Programmiersprache ( 4D v20.6)