Solved

T-SQL  While Loop

Posted on 2008-10-07
4
630 Views
Last Modified: 2012-06-27
i am trying to pull in information from a MySQL db into my MSSQL db.
i have created a linked server called LINKEDSERVERDB
There are over 900k rows in the table in the MySQL db and when i try to use a simple openquery select statement i get an error. I can pull back up to 600k rows.
I was thinking maybe if i use a while loop i would be able to insert 250k rows at a time into a temp table in my MSSQL db.
I have tried to write a while loop but i am now getting an error stating :

Cannot process the object "0,250000". The OLE DB provider "MSDASQL" for linked server
 "LINKEDSERVERDB" indicates that either the object has
no columns or the current user does not have permissions on that object

I don't know how i wouldn't have permissions with my linked serer, i set it up the same way as i do all my linked servers?
i have attached the code i have tried to use.
i would really appriciate if anyone could try and advise me please.

Kind Regards,
putoch

--Create table in MSSQL 
 
create table Imagine_prequal_temp(
id int not null, 
prefix varchar(5) not null,
number varchar(12)not null ,
mprefix varchar(5)null,
mnumber varchar(12)null,
fname varchar(40)null,
sname varchar(40)null,
prequalid int null,
testdate varchar(10)null,
result varchar(100)null,
result_code int null,
maxbw varchar(10)null,
description varchar (255)null,
checked datetime not null, 
step varchar(20)null,
company int null , 
IP varchar (15) null , 
contact int null ,
processed int null)
 
create unique Clustered index prequalindx on Imagine_Prequal_temp(id)
create index prequalindx1 on Imagine_Prequal_temp (prefix,number)
 
 
--WHILE LOOP 
TRUNCATE TABLE [BossDataView].[dbo].Imagine_prequal_temp;
 
GO
 
BEGIN
 
 
DECLARE @record_count INT, @while_counter INT, @limit_start INT, @limit_amount INT
 
SET @limit_start=0
SET @limit_amount=250000
SET @while_counter=-1
 
SELECT @record_count=count(*) FROM [BossDataView].[dbo].[IMAGINE_PREQUAL_TEMP]
 
WHILE @while_counter<@record_count
            BEGIN
                        DECLARE @final_query VARCHAR(255)
                        SET @final_query = CAST(@limit_start AS VARCHAR) + ',' + CAST(@limit_amount AS VARCHAR)
                        INSERT INTO [BossDataView].[dbo].[IMAGINE_PREQUAL_TEMP] 
                        EXEC('SELECT * FROM OPENQUERY(LINKEDSERVERDB,''' + @final_query + ''') AS subq');
                        SET @while_counter=@record_count
                        SELECT @record_count=count(*) FROM [BossDataView].[dbo].[IMAGEIN_PREQUAL_TEMP]
                        SET @limit_start= @limit_start + @limit_amount
            END
END

Open in new window

0
Comment
Question by:Putoch
4 Comments
 

Author Comment

by:Putoch
ID: 22661544
By using the simple openquery select from mysql db i was able to pull the data without getting the error above.
It was to do with my Advanced flag options on my ODBc connection
I went into http://dev.mysql.com/doc/refman/5.0/en/connector-odbc-configuration-connection-parameters.html
and checked what sort of information i was looking to bring over.

i choose: Large tables with too many rows which indicated to use(2049 )
So i choose :
2048 FLAG_COMPRESSED_PROTO Use Compressed Protocol
and
1 FLAG_FIELD_LENGTH Don't Optimize Column Width

This has allowed me to simply pull the data over using teh open query but i would still like some advise on the while query please/
0
 
LVL 18

Accepted Solution

by:
UnifiedIS earned 250 total points
ID: 22661618
The while condition doesn't test itself after each process so you need to include some login within the loop to determine whether it should break or continue

WHILE @while_counter<@record_count
  begin
        --do your inserts and counter updates

        --check if you should do it some more
        if @while_counter<@record_count
              continue
        else
            break
  end
0

Featured Post

Master Your Team's Linux and Cloud Stack

Come see why top tech companies like Mailchimp and Media Temple use Linux Academy to build their employee training programs.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
How can i make performance tuning to my sql query? 6 47
Sql Stored Procedure field variable 17 31
TSQL - How to declare table name 26 31
Complex MySQL Query 2 19
I'm trying, I really am. But I've seen so many wrong approaches involving date(time) boundaries I despair about my inability to explain it. I've seen quite a few recently that define a non-leap year as 364 days, or 366 days and the list goes on. …
In this article we will get to know that how can we recover deleted data if it happens accidently. We really can recover deleted rows if we know the time when data is deleted by using the transaction log.
This Micro Tutorial will give you a basic overview how to record your screen with Microsoft Expression Encoder. This program is still free and open for the public to download. This will be demonstrated using Microsoft Expression Encoder 4.
Although Jacob Bernoulli (1654-1705) has been credited as the creator of "Binomial Distribution Table", Gottfried Leibniz (1646-1716) did his dissertation on the subject in 1666; Leibniz you may recall is the co-inventor of "Calculus" and beat Isaac…

821 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question