The Schema collections return metadata for the Advanced SQL Engine objects. The notable metadata columns for the Period(Timestamp) data type are:
| Column Name | Description | 
|---|---|
| COLUMN_TYPE or DATA_TYPE | Set to PERIOD TIMESTAMP. | 
| DATETIME_PRECISION | The number of digits in the fractional seconds component of the Period(Timestamp) data type. The range of values are from Zero to Six. | 
| FORMAT | Format assigned to the SQL Engine object. | 
| PROVIDERDBTYPE | Set to TdType.PeriodTimestamp. | 
The TdDataReader.SchemaTable returns result set metadata. The notable metadata columns for the Period(Timestamp) data type are:
| Column Name | Description | 
|---|---|
| ColumnSize | The maximum length in Characters. | 
| NumericScale | The number of digits in the fractional seconds component of the Period(Timestamp) data type. The range of values are from Zero to Six. | 
| DataType | System.Type object for the System.String structure. | 
| ProviderType | Set to TdType.PeriodTimestamp. | 
| Format | Format assigned to the SQL Engine object. | 
| ProviderSpecificDataType | System.Type object for the TdPeriodTimestamp structure. | 
The following example shows how to configure a Period(Timestamp) parameter using DbType type declaration and a Base Class Library (BCL) value.
|  Note | 
|---|
| The Data Provider sends a VarChar data type to the SQL Engine when TdParameter.DbType is set to DbType.String. The SQL Engine will perform an implicit conversion to the Period(Timestamp) data type when required. The "SQL Functions, Operators, Expressions and Predicates" manual documents all implicit and explicit Data Type conversions. | 
| C# | Copy Code  | 
|---|---|
| TdParameter deliveryPeriod = new TdParameter(); deliveryPeriod.DbType = DbType.String; deliveryPeriod.Value = "(2011-01-01 00:00:00.000, 2011-12-31 23:59:59.999)"; | |
The following example shows how to configure a Period(Timestamp) parameter using TdType type declaration and a Provider Specific value. The TdParameter.Scale property reflects the maximum number of digits for the Fractional Second component and it must be equal to or less than the target SQL Engine object (i.e. Column, Expression, Stored Procedure Parameters and etc.) declaration. The range of values are from Zero to Six. It is recommend to always set TdParameter.Scale property, however the Data Provider will utilize TdPeriodTimestamp.Scale property value when the TdParameter.Scale, TdParameter.Precision and TdParameter.Size properties are set to zero. .NET Applications can retrieve metadata from the Schema Collections or the Schema Table and apply the metadata to the TdParameter object.
|  Note | 
|---|
| TdTimestamp.MaxValue is equivalent to the SQL Engine reserved word UNTIL_CHANGED | 
| C# | Copy Code  | 
|---|---|
| TdParameter deliveryPeriod = new TdParameter(); deliveryPeriod.TdType = TdType.PeriodTimestamp; // Maximum number of digits for the Fractional Second component. deliveryPeriod.Scale = 3; deliveryPeriod.ProviderSpecificValue = new TdPeriodTimestamp( new TdTimestamp(2011, 1, 1, 0, 0, 0), new TdTimestamp(2011, 12, 31, 23, 59, 59, 999000)); | |
The syntax for the Period(Timestamp) Literal is PERIOD'(YYYY-MM-DD hh:mi:ss.ffffff, YYYY-MM-DD hh:mi:ss.ffffff)'. Period(Timestamp) literals consist of the word PERIOD followed by character string literal representation of a beginning and ending bounds. The fractional seconds can vary from zero to six characters.
|  Note | 
|---|
| We recommend to always use Parameters in order to take advantage of the SQL Engine's Request Cache. | 
The following example shows a Period(Timestamp) Literal embedded in the command Text.
| C# | Copy Code  | 
|---|---|
| using (TdConnection cn = new TdConnection("data source=x;UserId=y;Password=z;")) { cn.Open(); TdCommand cmd = cn.CreateCommand(); cmd.CommandText = "INSERT INTO Policy (PolicyId, Validity) VALUES (2001, PERIOD'(2011-01-01 08:00:00.000, 2011-01-31 17:00:00.000)')"; cmd.ExecuteNonQuery(); } | |
The following methods and properties return the column or parameter value as a System.String structure.
The following methods and properties return the column or parameter value as a TdPeriodTimestamp structure.
| C# | Copy Code  | 
|---|---|
| using (TdConnection cn = new TdConnection("data source=DS1;UserId=Joe;Password=XY;")) { cn.Open(); TdCommand cmd = cn.CreateCommand(); cmd.CommandText = "SELECT PolicyId, Validity from Policy where Validity > ?"; cmd.Parameters.Add("Validity", TdType.PeriodTimestamp); cmd.Parameters[0].Scale = 3; cmd.Parameters[0].Value = new TdPeriodTimestamp(new TdTimestamp(2011, 1, 1, 8, 0, 0), new TdTimestamp(2011, 1, 31, 16, 59, 59, 999000) ); using (TdDataReader reader = cmd.ExecuteReader()) { if (reader.HasRows) { while (reader.Read()) { Console.WriteLine("[String] Policy Validity = {0}", reader.GetString(1)); Console.WriteLine("[TdPeriodTimestamp] Policy Validity = {0}", reader.GetTdPeriodTimestamp(1).ToString()); } } } } /* Output: [String] Policy Validity = (2011-02-01 09:30:000, 2011-12-31 16:59:59.999) [TdPeriodTimestamp] Policy Validity = (2011-02-01 09:30:00.000, 2011-12-31 16:59:59.999) */ | |
Accessor Methods for Retrieving Data
Configuring Parameters and Parameter Data Types