/* * Binary Data - Our test binary data is a 1 pixel gif. The basic (raw) data is below. Quoting this data would involve this (encode) method and be (encoded) with the 0x prefix for raw SQL. In other clients the (raw_db) value without the 0x prefix would need to be (packed) again yield the original (raw) value. (raw) - "GIF89a\001\000\001\000\221\000\000\377\377\377\377\377\377\376\001\002\000\000\000!\371\004\004\024\000\377\000,\000\000\000\000\001\000\001\000\000\002\002D\001\000;" (encode) - "0x#{raw.unpack("H*")[0]}" (encoded) - "0x47494638396101000100910000fffffffffffffe010200000021f904041400ff002c00000000010001000002024401003b" (raw_db) - "47494638396101000100910000fffffffffffffe010200000021f904041400ff002c00000000010001000002024401003b" (packed) - [raw_db].pack('H*') */ CREATE TABLE [dbo].[datatypes] ( [id] [int] NOT NULL IDENTITY(1,1) PRIMARY KEY, [bigint] [bigint] NULL, [binary_50] [binary](50) NULL, [bit] [bit] NULL, [char_10] [char](10) NULL, [date] [date] NULL, [datetime] [datetime] NULL, [datetime2_7] [datetime2](7) NULL, [datetimeoffset_2] [datetimeoffset](2) NULL, [datetimeoffset_7] [datetimeoffset](7) NULL, [decimal_9_2] [decimal](9, 2) NULL, [decimal_16_4] [decimal](16, 4) NULL, [float] [float] NULL, [geography] [geography] NULL, [geometry] [geometry] NULL, [hierarchyid] [hierarchyid] NULL, [image] [image] NULL, [int] [int] NULL, [money] [money] NULL, [nchar_10] [nchar](10) NULL, [ntext] [ntext] NULL, [numeric_18_0] [numeric](18, 0) NULL, [numeric_36_2] [numeric](36, 2) NULL, [nvarchar_50] [nvarchar](50) NULL, [nvarchar_max] [nvarchar](max) NULL, [real] [real] NULL, [smalldatetime] [smalldatetime] NULL, [smallint] [smallint] NULL, [smallmoney] [smallmoney] NULL, [text] [text] NULL, [time_2] [time](2) NULL, [time_7] [time](7) NULL, [timestamp] [timestamp] NULL, [tinyint] [tinyint] NULL, [uniqueidentifier] [uniqueidentifier] NULL, [varbinary_50] [varbinary](50) NULL, [varbinary_max] [varbinary](max) NULL, [varchar_50] [varchar](50) NULL, [varchar_max] [varchar](max) NULL, [xml] [xml] NULL ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY] SET IDENTITY_INSERT [datatypes] ON INSERT INTO [datatypes] ([id], [bigint]) VALUES ( 11, -9223372036854775807 ) INSERT INTO [datatypes] ([id], [bigint]) VALUES ( 12, 9223372036854775806 ) INSERT INTO [datatypes] ([id], [binary_50]) VALUES ( 21, 0x47494638396101000100910000fffffffffffffe010200000021f904041400ff002c00000000010001000002024401003b ) INSERT INTO [datatypes] ([id], [bit]) VALUES ( 31, 1 ) INSERT INTO [datatypes] ([id], [bit]) VALUES ( 32, 0 ) INSERT INTO [datatypes] ([id], [char_10]) VALUES ( 41, '1234567890' ) INSERT INTO [datatypes] ([id], [char_10]) VALUES ( 42, '12345678' ) INSERT INTO [datatypes] ([id], [date]) VALUES ( 51, '0001-01-01' ) INSERT INTO [datatypes] ([id], [date]) VALUES ( 52, '9999-12-31' ) INSERT INTO [datatypes] ([id], [datetime]) VALUES ( 61, '1753-01-01T00:00:00.000' ) INSERT INTO [datatypes] ([id], [datetime]) VALUES ( 62, '9999-12-31T23:59:59.997' ) INSERT INTO [datatypes] ([id], [datetime]) VALUES ( 63, '2010-01-01T12:34:56.123' ) INSERT INTO [datatypes] ([id], [datetime2_7]) VALUES ( 71, '0001-01-01T00:00:00.0000000Z' ) INSERT INTO [datatypes] ([id], [datetime2_7]) VALUES ( 72, '1984-01-24T04:20:00.0000000-08:00' ) INSERT INTO [datatypes] ([id], [datetime2_7]) VALUES ( 73, '9999-12-31T23:59:59.9999999Z' ) INSERT INTO [datatypes] ([id], [datetimeoffset_2]) VALUES ( 81, '1984-01-24T04:20:00.0000000-08:00' ) -- 1984-01-24 04:20:00.00 -08:00 INSERT INTO [datatypes] ([id], [datetimeoffset_2]) VALUES ( 82, '1984-01-24T04:20:00.0000000Z' ) -- 1984-01-24 04:20:00.00 +00:00 INSERT INTO [datatypes] ([id], [datetimeoffset_2]) VALUES ( 83, '9999-12-31T23:59:59.9999999Z' ) -- 9999-12-31 23:59:59.99 +00:00 INSERT INTO [datatypes] ([id], [datetimeoffset_7]) VALUES ( 84, '1984-01-24T04:20:00.0000000-08:00' ) -- 1984-01-24 04:20:00.0000000 -08:00 INSERT INTO [datatypes] ([id], [datetimeoffset_7]) VALUES ( 85, '1984-01-24T04:20:00.0000000Z' ) -- 1984-01-24 04:20:00.0000000 +00:00 INSERT INTO [datatypes] ([id], [datetimeoffset_7]) VALUES ( 86, '9999-12-31T23:59:59.9999999Z' ) -- 9999-12-31 23:59:59.9999999 +00:00 INSERT INTO [datatypes] ([id], [decimal_9_2]) VALUES ( 91, 12345.01 ) INSERT INTO [datatypes] ([id], [decimal_9_2]) VALUES ( 92, 1234567.89 ) INSERT INTO [datatypes] ([id], [decimal_16_4]) VALUES ( 93, 0.0 ) INSERT INTO [datatypes] ([id], [decimal_16_4]) VALUES ( 94, 123456789012.3456 ) INSERT INTO [datatypes] ([id], [float]) VALUES ( 101, 123.00000001 ) INSERT INTO [datatypes] ([id], [float]) VALUES ( 102, 0.0 ) INSERT INTO [datatypes] ([id], [float]) VALUES ( 103, 123.45 ) INSERT INTO [datatypes] ([id], [geography]) VALUES ( 111, geography::STGeomFromText('LINESTRING(-122.360 47.656, -122.343 47.656)', 4326) ) -- 0xE610000001148716D9CEF7D34740D7A3703D0A975EC08716D9CEF7D34740CBA145B6F3955EC0 INSERT INTO [datatypes] ([id], [geometry]) VALUES ( 121, geometry::STGeomFromText('LINESTRING (100 100, 20 180, 180 180)', 0) ) -- 0x0000000001040300000000000000000059400000000000005940000000000000344000000000008066400000000000806640000000000080664001000000010000000001000000FFFFFFFF0000000002 INSERT INTO [datatypes] ([id], [hierarchyid]) VALUES ( 131, CAST('/1/' AS hierarchyid) ) -- 0x58 INSERT INTO [datatypes] ([id], [hierarchyid]) VALUES ( 132, CAST('/2/' AS hierarchyid) ) -- 0x68 INSERT INTO [datatypes] ([id], [image]) VALUES ( 141, 0x47494638396101000100910000fffffffffffffe010200000021f904041400ff002c00000000010001000002024401003b ) INSERT INTO [datatypes] ([id], [int]) VALUES ( 151, -2147483647 ) INSERT INTO [datatypes] ([id], [int]) VALUES ( 152, 2147483646 ) INSERT INTO [datatypes] ([id], [money]) VALUES ( 161, 4.20 ) INSERT INTO [datatypes] ([id], [money]) VALUES ( 162, -922337203685477.5807 ) INSERT INTO [datatypes] ([id], [money]) VALUES ( 163, 922337203685477.5806 ) INSERT INTO [datatypes] ([id], [nchar_10]) VALUES ( 171, N'1234567890' ) INSERT INTO [datatypes] ([id], [nchar_10]) VALUES ( 172, N'123456åå' ) INSERT INTO [datatypes] ([id], [nchar_10]) VALUES ( 173, N'abc123' ) INSERT INTO [datatypes] ([id], [ntext]) VALUES ( 181, N'test ntext' ) INSERT INTO [datatypes] ([id], [ntext]) VALUES ( 182, N'test ntext åå' ) INSERT INTO [datatypes] ([id], [numeric_18_0]) VALUES ( 191, 191 ) INSERT INTO [datatypes] ([id], [numeric_18_0]) VALUES ( 192, 123456789012345678 ) INSERT INTO [datatypes] ([id], [numeric_36_2]) VALUES ( 193, 12345678901234567890.01 ) INSERT INTO [datatypes] ([id], [numeric_36_2]) VALUES ( 194, 123.46 ) INSERT INTO [datatypes] ([id], [nvarchar_50]) VALUES ( 201, N'test nvarchar_50' ) INSERT INTO [datatypes] ([id], [nvarchar_50]) VALUES ( 202, N'test nvarchar_50 åå' ) INSERT INTO [datatypes] ([id], [nvarchar_max]) VALUES ( 211, N'test nvarchar_max' ) INSERT INTO [datatypes] ([id], [nvarchar_max]) VALUES ( 212, N'test nvarchar_max åå' ) INSERT INTO [datatypes] ([id], [real]) VALUES ( 221, 123.45 ) INSERT INTO [datatypes] ([id], [real]) VALUES ( 222, 0.0 ) INSERT INTO [datatypes] ([id], [real]) VALUES ( 223, 0.00001 ) INSERT INTO [datatypes] ([id], [smalldatetime]) VALUES ( 231, '1901-01-01T15:45:00.000Z' ) -- 1901-01-01 15:45:00 INSERT INTO [datatypes] ([id], [smalldatetime]) VALUES ( 232, '2078-06-05T04:20:00.000Z' ) -- 2078-06-05 04:20:00 INSERT INTO [datatypes] ([id], [smallint]) VALUES ( 241, -32767 ) INSERT INTO [datatypes] ([id], [smallint]) VALUES ( 242, 32766 ) INSERT INTO [datatypes] ([id], [smallmoney]) VALUES ( 251, 4.20 ) INSERT INTO [datatypes] ([id], [smallmoney]) VALUES ( 252, -214748.3647 ) INSERT INTO [datatypes] ([id], [smallmoney]) VALUES ( 253, 214748.3646 ) INSERT INTO [datatypes] ([id], [text]) VALUES ( 271, 'test text' ) INSERT INTO [datatypes] ([id], [time_2]) VALUES ( 281, '1901-01-01T15:45:00.0100001Z' ) -- 15:45:00.01 INSERT INTO [datatypes] ([id], [time_2]) VALUES ( 282, '1984-01-24T04:20:00.0000001-08:00' ) -- 04:20:00.00 INSERT INTO [datatypes] ([id], [time_7]) VALUES ( 283, '1901-01-01T15:45:00.0100001Z' ) -- 15:45:00.0100001 INSERT INTO [datatypes] ([id], [time_7]) VALUES ( 284, '1984-01-24T04:20:00.0000001-08:00' ) -- 04:20:00.0000001 INSERT INTO [datatypes] ([id], [tinyint]) VALUES ( 301, 0 ) INSERT INTO [datatypes] ([id], [tinyint]) VALUES ( 302, 255 ) INSERT INTO [datatypes] ([id], [uniqueidentifier]) VALUES ( 311, NEWID() ) INSERT INTO [datatypes] ([id], [varbinary_50]) VALUES ( 321, 0x47494638396101000100910000fffffffffffffe010200000021f904041400ff002c00000000010001000002024401003b ) INSERT INTO [datatypes] ([id], [varbinary_max]) VALUES ( 331, 0x47494638396101000100910000fffffffffffffe010200000021f904041400ff002c00000000010001000002024401003b ) INSERT INTO [datatypes] ([id], [varchar_50]) VALUES ( 341, 'test varchar_50' ) INSERT INTO [datatypes] ([id], [varchar_max]) VALUES ( 351, 'test varchar_max' ) INSERT INTO [datatypes] ([id], [xml]) VALUES ( 361, 'batz' ) SET IDENTITY_INSERT [datatypes] OFF