The Schema collections return metadata for the Advanced SQL Engine objects. The notable metadata columns for the JSON data type are:
| Column Name | Description | 
|---|---|
| COLUMN_TYPE or DATA_TYPE | Set to JSON. | 
| CHARACTER_MAXIMUM_LENGTH | Returns the maximum length of the column in Characters. | 
| CHARACTER_OCTET_LENGTH | Returns the maximum length of the column in Bytes. This field is set to "CHARACTER_MAXIMUM_LENGTH * 2" for Unicode Character columns. | 
| FORMAT | Format assigned to the SQL Engine object. | 
| CHAR_TYPE | Indicates whether the columns is of type: 
 | 
| PROVIDERDBTYPE | It is set to TdType.Json. | 
The TdDataReader.SchemaTable returns result set metadata. The notable metadata columns for the Clob data type are:
| Column Name | Description | 
|---|---|
| ColumnSize | Returns the maximum length of the column in Characters. | 
| DataType | System.Type object for the System.String type. | 
| ProviderType | Set to TdType.Json. | 
| Format | Format assigned to the SQL Engine object. | 
| ProviderSpecificDataType | System.Type object for the TdClob class. | 
The following example shows how to configure a Json parameter using DbType type declaration, Size property and a BCL value. The value is set to a System.String instance.
| C# | Copy Code  | 
|---|---|
| TdParameter biography = new TdParameter(); biography.ParameterName = "Name"; biography.DbType = DbType.String; biography.Size = 64001; biography.Value = "{\"First\": \"John\", \"Last\": \"Smith\"}"; | |
|  Note | 
|---|
| The Data Provider maps DbType.String to the SQL Engine VarChar Data Type when Size is less than or equal to 64,000 characters. The Data Provider maps DbType.String to the SQL Engine CLOB Data Type when Size is greater than 64,000. | 
The following example shows how to configure a Json parameter using TdType type declaration and a BCL value.
| C# | Copy Code  | 
|---|---|
| TdParameter biography = new TdParameter(); biography.ParameterName = "Name"; biography.TdType = TdType.Json; biography.Value = "{\"First\": \"John\", \"Last\": \"Smith\"}"; | |
The TdParameter.Value should be set to an Array of Characters (Char[]), a String object or an instance of System.IO.TextReader.
The TdParameter.Size property must be set to a number greater than Zero for InputOutput or Output Parameters. The Data Provider will throw an exception when TdParameter.Direction property is set to ParameterDirection.Output or ParameterDirection.InputOutput and TdParameter.Size property is set to Zero. The TdParameter.Size property specifies the maximum number of Unicode Characters the Data Provider will send to the SQL Engine and/or receive from the SQL Engine. We recommend to set the TdParameter.Size property to the corresponding SQL Engine object size (e.g. Column or Stored Procedure Parameter size) for Input, InputOutput or Output parameters.
The following methods return the column or parameter value as a System.Char[] object.
The following methods and properties return the column or parameter value as a System.String object.
The following methods and properties return the column or parameter value as a TdClob class.
|  Note | 
|---|
| The CommandBehavior (see TdCommand.ExecuteReader(CommandBehavior)) must not include CommandBehavior.SequentialAccess. | 
The following method returns the column or parameter value as a System.TextReader object.
|  Note | 
|---|
| The CommandBehavior.SequentialAccess can potentially result in best overall performance. However in this mode JSON data cannot be transformed to a TdClob object. The CommandBehavior.SequentialAccess reduces the overall messages between the Data Provider and the SQL Engine because LOBs are transmitted to the Data Provider in Inline-mode. | 
Accessor Methods for Retrieving Data
Configuring Parameters and Parameter Data Types