Load data with INSERT into Parallel Data Warehouse
You can use the tsql INSERT statement to load data into a SQL Server Parallel Data Warehouse (PDW) distributed or replicated table. For more information about INSERT, see INSERT. For replicated tables and all non-distribution columns in a distributed table, PDW uses SQL Server to implicitly convert the data values specified in the statement to the data type of the destination column. For more information about SQL Server data conversion rules, see Data type conversion for SQL. However, for distribution columns, PDW supports only a subset of implicit conversions that SQL Server supports. Therefore, when you use the INSERT statement to load data into a distribution column, the source data must be specified in one of the formats defined in the following tables.
Insert literals into binary types
The following table defines the accepted literal types, format, and conversion rules for inserting a literal value into a distribution column of type binary (n) or varbinary(n).
Literal type | Format | Conversion rules |
---|---|---|
Binary literal | 0xhexadecimal_string Example: 0x12Ef |
Binary literals must be prefixed with 0x. The data source length cannot exceed the number of bytes specified for the data type. If the data source length is less than size of the binary data type, the data is padded to the right with zeros to reach the data type size. |
Insert literals into date and time types
Date and time literals are represented by using character values in specific formats, enclosed in single quotation marks. The following tables define the allowed literal types, format, and conversion rules for inserting a date or time literal into a SQL Server PDW distribution column of type datetime, smalldatetime, date, time, datetimeoffset, or datetime2.
datetime data type
The following table defines the accepted formats and rules for inserting literal values into a distribution column of type datetime. Any empty string ('') is converted to the default value '1900-01-01 12:00:00.000'. Strings that contain only blanks (' ') generate an error.
Literal type | Format | Conversion rules |
---|---|---|
String literal in datetime format | 'YYYY-MM-DD hh:mm:ss[.nnn]' Example: '2007-05-08 12:35:29.123' |
Missing fractional digits are set to 0 when the value is inserted. For example, the literal '2007-05-08 12:35' is inserted as '2007-05-08 12:35:00.000'. |
String literal in smalldatetime format | 'YYYY-MM-DD hh:mm' Example: '2007-05-08 12:35' |
Seconds and remaining fractional digits are set to 0 when the value is inserted. |
String literal in date format | 'YYYY-MM-DD' Example: '2007-05-08' |
Time values (hour, minutes, seconds, and fractions) are set to 12:00:00.000 when the value is inserted. |
String literal in datetime2 format | 'YYYY-MM-DD hh:mm:ss.nnnnnnn' Example: '2007-05-08 12:35:29.1234567' |
The source data cannot exceed three fractional digits. For example, the literal '2007-05-08 12:35:29.123' will be inserted, but the value '2007-05-08 12:35:29.1234567' generates an error. |
smalldatetime data type
The following table defines the accepted formats and rules for inserting literal values into a distribution column of type smalldatetime. Any empty string ('') is converted to the default value '1900-01-01 12:00'. Strings that contain only blanks (' ') generate an error.
Literal type | Format | Conversion rules |
---|---|---|
String literal in smalldatetime format | 'YYYY-MM-DD hh:mm' or 'YYYY-MM-DD hh:mm:00' Example: '2007-05-08 12:00' or '2007-05-08 12:00:00' |
The source data must have values for year, month, date, hour and minute. Seconds are optional and, if present, must be set to the value 00. Any other value generates an error. |
String literal in date format | 'YYYY-MM-DD' Example: '2007-05-08' |
Time values (hour, minutes, seconds, and fractions) are set to 0 when the value is inserted. |
date data type
The following table defines the accepted formats and rules for inserting literal values into a distribution column of type date. Any empty string ('') is converted to the default value '1900-01-01'. Strings that contain only blanks (' ') generate an error.
Literal type | Format | Conversion rules |
---|---|---|
String literal in date format | 'YYYY-MM-DD' Example: '2007-05-08' |
This is the only accepted format. |
time data type
The following table defines the accepted formats and rules for inserting literal values into a distribution column of type time. Any empty string ('') is converted to the default value '00:00:00.0000'. Strings that contain only blanks (' ') generate an error.
Literal type | Format | Conversion rules |
---|---|---|
String literal in time format | 'hh:mm:ss.nnnnnnn' Example: '12:35:29.1234567' |
If the data source has a smaller or equal precision (number of fractional digits) than the precision of the time data type, the data is padded to the right with zeros. For example, a literal value '12:35:29.123' is inserted as '12:35:29.1230000'. A value that has a larger precision than the target data type is rejected. |
datetimeoffset data type
The following table defines the accepted formats and rules for inserting literal values into a distribution column of type datetimeoffset (n). The default format is 'YYYY-MM-DD hh:mm:ss.nnnnnnn {+|-}hh:mm'. An empty string ('') is converted to the default value '1900-01-01 12:00:00.0000000 +00:00'. Strings that contain only blanks (' ') generate an error. The number of fractional digits depends on the column definition. For example, a column defined as datetimeoffset (2) will have two fractional digits.
Literal type | Format | Conversion rules |
---|---|---|
String literal in datetime format | 'YYYY-MM-DD hh:mm:ss[.nnn]' Example: '2007-05-08 12:35:29.123' |
Missing fractional digits and offset values are set to 0 when the value is inserted. For example, the literal '2007-05-08 12:35:29.123' is inserted as '2007-05-08 12:35:29.1230000 +00:00'. |
String literal in smalldatetime format | 'YYYY-MM-DD hh:mm' Example: '2007-05-08 12:35' |
Seconds, remaining fractional digits and offset values are set to 0 when the value is inserted. |
String literal in date format | 'YYYY-MM-DD' Example: '2007-05-08' |
Time values (hour, minutes, seconds, and fractions) are set to 0 when the value is inserted. For example, the literal '2007-05-08' is inserted as '2007-05-08 00:00:00.0000000 +00:00'. |
String literal in datetime2 format | 'YYYY-MM-DD hh:mm:ss.nnnnnnn' Example: '2007-05-08 12:35:29.1234567' |
The source data cannot exceed the specified number of fractional seconds in the datetimeoffset column. If the data source has a smaller or equal number of fractional seconds, the data is padded to the right with zeros. For example, if the data type is datetimeoffset (5), the literal value '2007-05-08 12:35:29.123 +12:15' is inserted as '12:35:29.12300 +12:15'. |
String literal in datetimeoffset format | 'YYYY-MM-DD hh:mm:ss.nnnnnnn {+|-} hh:mm' Example: '2007-05-08 12:35:29.1234567 +12:15' |
The source data cannot exceed the specified number of fractional seconds in the datetimeoffset column. If the data source has a smaller or equal number of fractional seconds, the data is padded to the right with zeros. For example, if the data type is datetimeoffset (5), the literal value '2007-05-08 12:35:29.123 +12:15' is inserted as '12:35:29.12300 +12:15'. |
datetime2 data type
The following table defines the accepted formats and rules for inserting literal values into a distribution column of type datetime2 (n). The default format is 'YYYY-MM-DD hh:mm:ss.nnnnnnn'. An empty string ('') is converted to the default value '1900-01-01 12:00:00'. Strings that contain only blanks (' ') generate an error. The number of fractional digits depends on the column definition. For example, a column defined as datetime2 (2) will have two fractional digits.
Literal type | Format | Conversion rules |
---|---|---|
String literal in datetime format | 'YYYY-MM-DD hh:mm:ss[.nnn]' Example: '2007-05-08 12:35:29.123' |
Fractional seconds are optional and are set to 0 when the value is inserted. A value that has more fractional digits than the target data type is rejected. |
String literal in smalldatetime format | 'YYYY-MM-DD hh:mm' Example: '2007-05-08 12' |
Optional seconds and remaining fractional digits are set to 0 when the value is inserted. |
String literal in date format | 'YYYY-MM-DD' Example: '2007-05-08' |
Time values (hour, minutes, seconds, and fractions) are set to 0 when the value is inserted. For example, the literal '2007-05-08' is inserted as '2007-05-08 12:00:00.0000000'. |
String literal in datetime2 format | 'YYYY-MM-DD hh:mm:ss:nnnnnnn' Example: '2007-05-08 12:35:29.1234567' |
If the data source contains data and time components that are less than or equal to the value specified in datetime2(n), the data is inserted; otherwise an error is generated. |
Insert literals into numeric types
The following tables define the accepted formats and conversion rules for inserting a literal value into a SQL Server PDW distribution column that uses a numeric type.
bit data type
The following table defines the accepted formats and rules for inserting literal values into a distribution column of type bit. An empty string ('') or a string that contain only blanks (' ') is converted to 0.
Literal type | format | Conversion rules |
---|---|---|
String literal in integer format | 'nnnnnnnnnn' Example: '1' or '321' |
An integer value formatted as a string literal cannot contain a negative value. For example, the value '-123' generates an error. A value larger than 1 is converted to 1. For example, the value '123' is converted to 1. |
String literal | 'TRUE' or 'FALSE' Example: 'true' |
The value 'TRUE' is converted to 1; the value 'FALSE' is converted to 0. |
Integer literal | nnnnnnnn Example: 1 or 321 |
A value larger than 1 or less than 0 is converted to 1. For example, the values 123 and -123 are converted to 1. |
Decimal literal | nnnnn.nnnn Example: 1234.5678 |
A value larger than 1 or less than 0 is converted to 1. For example, the values 123.45 and -123.45 are converted to 1. |
decimal data type
The following table defines the accepted formats and rules for inserting literal values into a distribution column of type decimal (p,s). The data conversion rules are the same as for SQL Server. For more information, see Data type conversion on MSDN.
Literal type | Format |
---|---|
String literal in integer format | 'nnnnnnnnnnnn' Example: '321312313123' |
String literal in decimal format | 'nnnnnn.nnnnn' Example: '123344.34455' |
Integer literal | nnnnnnnnnnnn Example: 321312313123 |
Decimal literal | nnnnnn.nnnnn Example: '123344.34455' |
float and real data types
The following table defines the accepted formats and rules for inserting literal values into a distribution column of type float or real. Data conversion rules are the same as for SQL Server. For more information, see Data type conversion on MSDN.
Literal type | Format |
---|---|
String literal in integer format | 'nnnnnnnnnnnn' Example: '321312313123' |
String literal in decimal format | 'nnnnnn.nnnnn' Example: '123344.34455' |
String literal in floating point format | 'n.nnnnnE+nn' Example: '3.12323E+14' |
Integer literal | nnnnnnnnnnnn Example: 321312313123 |
Decimal literal | nnnnnn.nnnnn Example: 123344.34455 |
Floating point literal | n.nnnnnE+nn Example: 3.12323E+14 |
int, bigint, tinyint, smallint data types
The following table defines the accepted formats and rules for inserting literal values into a distribution column of type int, bigint, tinyint, or smallint. The data source cannot exceed the range allowed for the given data type. For example, the range for tinyint is 0 to 255 and the range for int is -2,147,483,648 to 2,147,483,647.
Literal Type | Format | Conversion Rules |
---|---|---|
String literal in integer format | 'nnnnnnnnnnnnnn' Example: '321312313123' |
None |
Integer literal | nnnnnnnnnnnnnn Example: 321312313123 |
None |
Decimal literal | nnnnnn.nnnnn Example: 123344.34455 |
The values to the right of the decimal point are truncated. |
money and smallmoney data types
Money literal values are represented as numbers with an optional decimal point and currency symbol as a prefix. The data source cannot exceed the range allowed for the given data type. For example, the range for smallmoney is -214,748.3648 to 214,748.3647 and the range for money is -922,337,203,685,477.5808 to 922,337,203,685,477.5807. The following table defines the accepted formats and rules for inserting literal values into a distribution column of type money or smallmoney.
Literal type | Format | Conversion rules |
---|---|---|
String literal in integer format | 'nnnnnnnn' Example: '123433' |
Missing digits after the decimal point are set to 0 when the value is inserted. For example, the literal '12345' is inserted as 12345.0000. |
String literal in decimal format | 'nnnnnn.nnnnn' Example: '123344.34455' |
If the number of digits after the decimal point exceed 4, the value is rounded up to the nearest value. For example, the value '123344.34455' is inserted as 123344.3446. |
String literal in money format | '$nnnnnn.nnnn' Example: '$123456.7890' |
The optional currency symbol is not inserted with the value. If the number of digits after the decimal point exceed 4, the value is rounded up to the nearest value. |
Integer literal | nnnnnnnn Example: 123433 |
Missing digits after the decimal point are set to 0 when the value is inserted. For example, the literal 12345 is inserted as 12345.0000. |
Decimal literal | nnnnnn.nnnnn Example: 123344.34455 |
If the number of digits after the decimal point exceed 4, the value is rounded up to the nearest value. For example, the value 123344.34455 is inserted as 123344.3446. |
Money literal | $nnnnnn.nnnn Example: $123456.7890 |
The optional currency symbol is not inserted with the value. If the number of digits after the decimal point exceed 4, the value is rounded up to the nearest value. |
Inserting literals into string types
The following tables define the accepted formats and conversion rules for inserting a literal value into a SQL Server PDW column that uses a string type.
char, varchar, nchar and nvarchar data types
The following table defines the accepted formats and rules for inserting literal values into a distribution column of type char, varchar, nchar and nvarchar. The data source length cannot exceed the size specified for the data type. If the data source length is less than size of the char or nchar data type, the data is padded to the right with blank spaces to reach the data type size.
Literal Type | Format | Conversion rules |
---|---|---|
String literal | Format: 'character string' Example: 'abc' |
None |
Unicode string literal | Format: N'character string' Example: N'abc' |
None |
Integer literal | Format: nnnnnnnnnnn Example: 321312313123 |
None |
Decimal literal | Format: nnnnnn.nnnnnnn Example: 12344.34455 |
None |
Money literal | Format: $nnnnnn.nnnnn Example: $123456.99 |
The currency symbol is not inserted with the value. To insert the currency symbol, insert the value as a string literal. This will match the format of the dwloader tool, which treats every literal as a string literal. Commas are not allowed. If the number of digits after the decimal point exceed 2, the value is rounded up to the nearest value. For example, the value 123.946789 is inserted as 123.95. Only the default style 0 (no commas and 2 digits after the decimal point) is allowed when using the CONVERT function to insert money literals. |