Sample code for 30+ languages & platforms
SQL Server

CSV Insert Column

See more CSV Examples

Insert a new column into an existing CSV.

Note: This example requires Chilkat v9.5.0.89 or greater because the InsertColumn method was added in v9.5.0.89.

Chilkat SQL Server Downloads

SQL Server
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls.
--
CREATE PROCEDURE ChilkatSample
AS
BEGIN
    DECLARE @hr int
    -- Important: Do not use nvarchar(max).  See the warning about using nvarchar(max).
    DECLARE @sTmp0 nvarchar(4000)
    DECLARE @success int
    SELECT @success = 0

    DECLARE @csv int
    EXEC @hr = sp_OACreate 'Chilkat.Csv', @csv OUT
    IF @hr <> 0
    BEGIN
        PRINT 'Failed to create ActiveX component'
        RETURN
    END

    -- Load the following CSV:

    --  Name;City;Weight
    --  John;Chicago;180
    --  Lisa;Denver;120

    -- Indicate that the 1st line contains column names.
    EXEC sp_OASetProperty @csv, 'HasColumnNames', 1
    EXEC sp_OAMethod @csv, 'LoadFile', @success OUT, 'qa_data/csv/insertColumnTest.csv'

    -- We can insert a column before the 1st column.
    EXEC sp_OAMethod @csv, 'InsertColumn', @success OUT, 0

    EXEC sp_OAMethod @csv, 'SaveToString', @sTmp0 OUT
    PRINT @sTmp0

    -- The CSV now looks like this:

    --  ;Name;City;Weight
    --  ;John;Chicago;180
    --  ;Lisa;Denver;120

    -- Set the cells in column 0.

    DECLARE @col int
    SELECT @col = 0
    EXEC sp_OAMethod @csv, 'SetColumnName', @success OUT, @col, 'id'
    EXEC sp_OAMethod @csv, 'SetCell', @success OUT, 0, @col, '100'
    EXEC sp_OAMethod @csv, 'SetCell', @success OUT, 1, @col, '101'

    EXEC sp_OAMethod @csv, 'SaveToString', @sTmp0 OUT
    PRINT @sTmp0

    -- We now have:

    --  id;Name;City;Weight
    --  100;John;Chicago;180
    --  101;Lisa;Denver;120

    -- Insert a new column between City and Weight
    -- In other words, add a new column before the Weight column.
    DECLARE @weightColumn int
    EXEC sp_OAMethod @csv, 'GetIndex', @weightColumn OUT, 'Weight'

    PRINT 'Weight Column Index = ' + @weightColumn
    EXEC sp_OAMethod @csv, 'InsertColumn', @success OUT, @weightColumn

    EXEC sp_OAMethod @csv, 'SaveToString', @sTmp0 OUT
    PRINT @sTmp0

    -- We now have:

    --  id;Name;City;;Weight
    --  100;John;Chicago;;180
    --  101;Lisa;Denver;;120

    -- Set the cells in the new column:

    EXEC sp_OAMethod @csv, 'SetColumnName', @success OUT, @weightColumn, 'Height'
    EXEC sp_OAMethod @csv, 'SetCell', @success OUT, 0, @weightColumn, '6'' 2"'
    EXEC sp_OAMethod @csv, 'SetCell', @success OUT, 1, @weightColumn, '5'' 7"'

    EXEC sp_OAMethod @csv, 'SaveToString', @sTmp0 OUT
    PRINT @sTmp0

    -- We now have:

    --  id;Name;City;Height;Weight
    --  100;John;Chicago;"6' 2""";180
    --  101;Lisa;Denver;"5' 7""";120

    EXEC @hr = sp_OADestroy @csv


END
GO