Openrowset don't show all columns

  • Hi,

    I use a OpenRowset Query to create a table in SQL Server from .txt file.

    The command don't show errors, but the table does not have all the columns. It only appears 255. The original file has 623 columns.

    The example is:

    SELECT * INTO TB_TEMPORAL

    FROM openrowset ('MSDASQL','Driver={Microsoft Text Driver (*.txt; *.csv)}; DefaultDir=C:\MG\;','SELECT * FROM XXX.txt')

    I need to use something similar because the columns may varies in the .txt.

    Thanks for your help.

  • try using ssis if that imports all the columns... how big is one record?

  • Thanks.

    Yes, SSIS is an option, but the txt files varies from load to load (less o more columns). For this reason is not posible use a SSIS.

    Any ideas?

  • Can’t you request for a common standard for the text , csv file? If you can initiate this SSIS is the way forward

  • It looks like if you change your provider to SQL Native Client, that it will work.

    I ran this code in a database named "Sandbox", and both queries return the 600 columns that I'm creating.

    if object_id('dbo.test') IS NOT NULL DROP TABLE dbo.Test

    declare @sql varchar(max)

    ;WITH

    TENS (N) AS (SELECT 0 UNION ALL SELECT 0 UNION ALL SELECT 0 UNION ALL

    SELECT 0 UNION ALL SELECT 0 UNION ALL SELECT 0 UNION ALL

    SELECT 0 UNION ALL SELECT 0 UNION ALL SELECT 0 UNION ALL SELECT 0),

    THOUSANDS (N) AS (SELECT 1 FROM TENS t1 CROSS JOIN TENS t2 CROSS JOIN TENS t3),

    MILLIONS (N) AS (SELECT 1 FROM THOUSANDS t1 CROSS JOIN THOUSANDS t2),

    TALLY (N) AS (SELECT ROW_NUMBER() OVER (ORDER BY (SELECT 0)) FROM MILLIONS)

    SELECT @sql = 'CREATE TABLE dbo.Test (' +

    STUFF((SELECT TOP (600) ',COL' + convert(varchar(3), N) + ' INT'

    FROM TALLY

    ORDER BY N

    FOR XML PATH('')),1,1,'') + ')'

    exec (@sql)

    select * from dbo.TEST

    SELECT a.*

    FROM OPENROWSET('SQLNCLI', 'Server=WS-HPDV7\SQL2008DEV;Trusted_Connection=yes;',

    'SELECT *

    FROM Sandbox.dbo.Test') AS a;

    Wayne
    Microsoft Certified Master: SQL Server 2008
    Author - SQL Server T-SQL Recipes


    If you can't explain to another person how the code that you're copying from the internet works, then DON'T USE IT on a production system! After all, you will be the one supporting it!
    Links:
    For better assistance in answering your questions
    Performance Problems
    Common date/time routines
    Understanding and Using APPLY Part 1 & Part 2

  • Thanks for your reply. I don't request a standard text file because is generated by a closed application. It's depends of the results of polls (less o more answers). This is the reason why the number of columns vary from load to load.

  • Did changing to the SQL Native Client driver help out? As I demonstrated, it seems to work for me.

    Wayne
    Microsoft Certified Master: SQL Server 2008
    Author - SQL Server T-SQL Recipes


    If you can't explain to another person how the code that you're copying from the internet works, then DON'T USE IT on a production system! After all, you will be the one supporting it!
    Links:
    For better assistance in answering your questions
    Performance Problems
    Common date/time routines
    Understanding and Using APPLY Part 1 & Part 2

  • WayneS (7/12/2010)


    Did changing to the SQL Native Client driver help out? As I demonstrated, it seems to work for me.

    Wayne i thought the OP was running into the fact that the JET text driver is limited to 255 columns; while the SQL native driver supports more, he was trying to import from text file and not another server, right?

    everything i googled said it was possible to get around the 255 CHAR to a column fix with IMEX=1, but no (direct) solution to 255 columns max for the JET driver.

    i don't think creating a schema.ini file will help either, as it's a limitation to JET on the # cols.

    i think he'll need to bulk insert into a staging table, and then use something like your solution after it is in SQL.

    Lowell


    --help us help you! If you post a question, make sure you include a CREATE TABLE... statement and INSERT INTO... statement into that table to give the volunteers here representative data. with your description of the problem, we can provide a tested, verifiable solution to your question! asking the question the right way gets you a tested answer the fastest way possible!

  • Lowell (7/12/2010)


    WayneS (7/12/2010)


    Did changing to the SQL Native Client driver help out? As I demonstrated, it seems to work for me.

    Wayne i thought the OP was running into the fact that the JET text driver is limited to 255 columns; while the SQL native driver supports more, he was trying to import from text file and not another server, right?

    everything i googled said it was possible to get around the 255 CHAR to a column fix with IMEX=1, but no (direct) solution to 255 columns max for the JET driver.

    i don't think creating a schema.ini file will help either, as it's a limitation to JET on the # cols.

    i think he'll need to bulk insert into a staging table, and then use something like your solution after it is in SQL.

    Thank you Wayne, but the solution not working, because is a text file.

  • leonardo.castillo (7/12/2010)


    Lowell (7/12/2010)


    WayneS (7/12/2010)


    Did changing to the SQL Native Client driver help out? As I demonstrated, it seems to work for me.

    Wayne i thought the OP was running into the fact that the JET text driver is limited to 255 columns; while the SQL native driver supports more, he was trying to import from text file and not another server, right?

    everything i googled said it was possible to get around the 255 CHAR to a column fix with IMEX=1, but no (direct) solution to 255 columns max for the JET driver.

    i don't think creating a schema.ini file will help either, as it's a limitation to JET on the # cols.

    i think he'll need to bulk insert into a staging table, and then use something like your solution after it is in SQL.

    Thank you Wayne, but the solution not working, because is a text file.

    Sorry Lowell, but you have a example of "staging table"'?

  • i'm thinking something like this:

    bring everything is as one big field...i'm assuming varchar(8000) would hold it, but it might need varchar(max).

    once in a table, use CHARINDEX2 to chop everything up into642 varchar columns....i'd create a view to make it easy, with cols F001 thru F642 or whatever it takes.

    /*

    Example:

    SELECT dbo.CHARINDEX2('a', 'abbabba', 3)

    returns the location of the third occurrence of 'a'

    which is 7

    */

    CREATE FUNCTION CHARINDEX2

    (

    @TargetStr varchar(8000),

    @SearchedStr varchar(8000),

    @Occurrence int

    )

    RETURNS int

    as

    begin

    declare @pos int, @counter int, @ret int

    set @pos = CHARINDEX(@TargetStr, @SearchedStr)

    set @counter = 1

    if @Occurrence = 1 set @ret = @pos

    else

    begin

    while (@counter < @Occurrence)

    begin

    select @ret = CHARINDEX(@TargetStr, @SearchedStr, @pos + 1)

    set @counter = @counter + 1

    set @pos = @ret

    end

    end

    RETURN(@ret)

    end

    GO

    CREATE TABLE STAGINGTABLE(RAWDATA VARCHAR (8000))

    BULK INSERT STAGINGTABLE FROM 'C:\MG\XXX.txt'

    WITH (

    DATAFILETYPE = 'char',

    FIELDTERMINATOR = '~', --a delimiter that does nto exist in the data

    ROWTERMINATOR = '{slash n}', --the real slash n cannot be displayed in the forum

    FIRSTROW = 1

    )

    --build this with excel or something for 623 fields:

    SELECT

    SUBSTRING(RAWDATA,1,dbo.CHARINDEX2(',',RAWDATA,1,1)-1) AS F001,

    SUBSTRING(RAWDATA,dbo.CHARINDEX2(',',RAWDATA,1,1)+1 ,dbo.CHARINDEX2(',',RAWDATA,1,2)-1) AS F002

    SUBSTRING(RAWDATA,dbo.CHARINDEX2(',',RAWDATA,1,2)+1 ,dbo.CHARINDEX2(',',RAWDATA,1,3)-1) AS F003

    ...

    SUBSTRING(RAWDATA,dbo.CHARINDEX2(',',RAWDATA,1,641)+1 ,dbo.CHARINDEX2(',',RAWDATA,1,642)-1) AS F641

    SUBSTRING(RAWDATA,dbo.CHARINDEX2(',',RAWDATA,1,642)+1,30) --assuming the last field is less than 30 chars.

    Lowell


    --help us help you! If you post a question, make sure you include a CREATE TABLE... statement and INSERT INTO... statement into that table to give the volunteers here representative data. with your description of the problem, we can provide a tested, verifiable solution to your question! asking the question the right way gets you a tested answer the fastest way possible!

  • Thanks, i will test it today. I will let you know if it works

    Lowell (7/12/2010)


    i'm thinking something like this:

    bring everything is as one big field...i'm assuming varchar(8000) would hold it, but it might need varchar(max).

    once in a table, use CHARINDEX2 to chop everything up into642 varchar columns....i'd create a view to make it easy, with cols F001 thru F642 or whatever it takes.

    /*

    Example:

    SELECT dbo.CHARINDEX2('a', 'abbabba', 3)

    returns the location of the third occurrence of 'a'

    which is 7

    */

    CREATE FUNCTION CHARINDEX2

    (

    @TargetStr varchar(8000),

    @SearchedStr varchar(8000),

    @Occurrence int

    )

    RETURNS int

    as

    begin

    declare @pos int, @counter int, @ret int

    set @pos = CHARINDEX(@TargetStr, @SearchedStr)

    set @counter = 1

    if @Occurrence = 1 set @ret = @pos

    else

    begin

    while (@counter < @Occurrence)

    begin

    select @ret = CHARINDEX(@TargetStr, @SearchedStr, @pos + 1)

    set @counter = @counter + 1

    set @pos = @ret

    end

    end

    RETURN(@ret)

    end

    GO

    CREATE TABLE STAGINGTABLE(RAWDATA VARCHAR (8000))

    BULK INSERT STAGINGTABLE FROM 'C:\MG\XXX.txt'

    WITH (

    DATAFILETYPE = 'char',

    FIELDTERMINATOR = '~', --a delimiter that does nto exist in the data

    ROWTERMINATOR = '{slash n}', --the real slash n cannot be displayed in the forum

    FIRSTROW = 1

    )

    --build this with excel or something for 623 fields:

    SELECT

    SUBSTRING(RAWDATA,1,dbo.CHARINDEX2(',',RAWDATA,1,1)-1) AS F001,

    SUBSTRING(RAWDATA,dbo.CHARINDEX2(',',RAWDATA,1,1)+1 ,dbo.CHARINDEX2(',',RAWDATA,1,2)-1) AS F002

    SUBSTRING(RAWDATA,dbo.CHARINDEX2(',',RAWDATA,1,2)+1 ,dbo.CHARINDEX2(',',RAWDATA,1,3)-1) AS F003

    ...

    SUBSTRING(RAWDATA,dbo.CHARINDEX2(',',RAWDATA,1,641)+1 ,dbo.CHARINDEX2(',',RAWDATA,1,642)-1) AS F641

    SUBSTRING(RAWDATA,dbo.CHARINDEX2(',',RAWDATA,1,642)+1,30) --assuming the last field is less than 30 chars.

Viewing 12 posts - 1 through 11 (of 11 total)

You must be logged in to reply to this topic. Login to reply