SQL Server
SQL Server
CSV Append a Column with Values
See more CSV Examples
Append an additional column and initialize with a value.Chilkat SQL Server Downloads
-- 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
-- First initialize the CSV with content.
-- permalink,company,numEmps,category,city,state,fundedDate,raisedAmt,raisedCurrency,round
-- lifelock,LifeLock,,web,Tempe,AZ,1-May-07,6850000,USD,b
-- mycityfaces,MyCityFaces,7,web,Scottsdale,AZ,1-Jan-08,50000,USD,seed
-- flypaper,Flypaper,,web,Phoenix,AZ,1-Feb-08,3000000,USD,a
-- infusionsoft,Infusionsoft,105,software,Gilbert,AZ,1-Oct-07,9000000,USD,a
-- gauto,gAuto,4,web,Scottsdale,AZ,1-Jan-08,250000,USD,seed
DECLARE @bCrlf int
SELECT @bCrlf = 1
DECLARE @sb int
EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sb OUT
IF @hr <> 0
BEGIN
PRINT 'Failed to create ActiveX component'
RETURN
END
EXEC sp_OAMethod @sb, 'AppendLine', @success OUT, 'permalink,company,numEmps,category,city,state,fundedDate,raisedAmt,raisedCurrency,round', @bCrlf
EXEC sp_OAMethod @sb, 'AppendLine', @success OUT, 'lifelock,LifeLock,,web,Tempe,AZ,1-May-07,6850000,USD,b', @bCrlf
EXEC sp_OAMethod @sb, 'AppendLine', @success OUT, 'mycityfaces,MyCityFaces,7,web,Scottsdale,AZ,1-Jan-08,50000,USD,seed', @bCrlf
EXEC sp_OAMethod @sb, 'AppendLine', @success OUT, 'flypaper,Flypaper,,web,Phoenix,AZ,1-Feb-08,3000000,USD,a', @bCrlf
EXEC sp_OAMethod @sb, 'AppendLine', @success OUT, 'infusionsoft,Infusionsoft,105,software,Gilbert,AZ,1-Oct-07,9000000,USD,a', @bCrlf
EXEC sp_OAMethod @sb, 'AppendLine', @success OUT, 'gauto,gAuto,4,web,Scottsdale,AZ,1-Jan-08,250000,USD,seed', @bCrlf
DECLARE @csv int
EXEC @hr = sp_OACreate 'Chilkat.Csv', @csv OUT
EXEC sp_OASetProperty @csv, 'HasColumnNames', 1
EXEC sp_OAMethod @sb, 'GetAsString', @sTmp0 OUT
EXEC sp_OAMethod @csv, 'LoadFromString', @success OUT, @sTmp0
-- Show the initial CSV:
EXEC sp_OAMethod @csv, 'SaveToString', @sTmp0 OUT
PRINT @sTmp0
PRINT '----'
-- Now let's add a new rightmost column.
DECLARE @numColumns int
EXEC sp_OAGetProperty @csv, 'NumColumns', @numColumns OUT
DECLARE @numRows int
EXEC sp_OAGetProperty @csv, 'NumRows', @numRows OUT
-- Set the column name.
DECLARE @columnIdx int
SELECT @columnIdx = @numColumns
EXEC sp_OAMethod @csv, 'SetColumnName', @success OUT, @columnIdx, 'new_column'
-- Add the column to each row.
DECLARE @i int
SELECT @i = 0
WHILE @i < @numRows
BEGIN
EXEC sp_OAMethod @csv, 'SetCell', @success OUT, @i, @columnIdx, 'newData'
SELECT @i = @i + 1
END
-- Show the updated CSV:
EXEC sp_OAMethod @csv, 'SaveToString', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @sb
EXEC @hr = sp_OADestroy @csv
END
GO