Solved

Problems with single quote character iwhen attempting to export data

Posted on 2010-09-15
10
204 Views
Last Modified: 2012-05-10
Hi,

I am attempting to use the following query, which works fine when run in sql server management studio, to export data:

SELECT
            '1',
            isnull(left(DISTRICT,1),' '),
            isnull(left(CTV,2),'  '),
            isnull(left(CTV2,5),'     ')          
FROM [CensusData].[dbo].[MainQuestionnaire$]

The export command follows:

EXEC xp_cmdshell 'bcp "SELECT
            '1',
            isnull(left(DISTRICT,1),' '),
            isnull(left(CTV,2),'  '),
            isnull(left(CTV2,5),'     ')            
FROM [CensusData].[dbo].[MainQuestionnaire$]" queryout "C:\bcptest.txt" -T -c -t -S "MYSERVER"'

I know that the problem is with the single quote characters but don't know how to fix it.

Please help.
0
Comment
Question by:sib_user
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 5
  • 3
  • 2
10 Comments
 
LVL 15

Expert Comment

by:AmmarR
ID: 33679900
Dear you can use the replace command

check the code below

replace(column name,'''','')
EXEC xp_cmdshell 'bcp "SELECT 
            '1', 
            isnull(left(replace(DISTRICT,'''',''),1),' '),
            isnull(left(replace(CTV,'''',''),2),'  '),,
            isnull(left(replace(CTV2,'''','')),'     ')            
FROM [CensusData].[dbo].[MainQuestionnaire$]" queryout "C:\bcptest.txt" -T -c -t -S "MYSERVER"' 

Open in new window

0
 
LVL 8

Expert Comment

by:Knut Hunstad
ID: 33679905
From the documentation:

---
command_string cannot contain more than one set of double quotation marks. A single pair of quotation marks is necessary if any spaces are present in the file paths or program names referenced by command_string. If you have trouble with embedded spaces, consider using FAT 8.3 file names as a workaround
---

So the problem seems to be your double quotation marks, not the single ones!

Try this:

EXEC xp_cmdshell 'bcp "SELECT
            '1',
            isnull(left(DISTRICT,1),' '),
            isnull(left(CTV,2),'  '),
            isnull(left(CTV2,5),'     ')            
FROM [CensusData].[dbo].[MainQuestionnaire$]" queryout C:\bcptest.txt -T -c -t -S MYSERVER'


Please note this suggestion is just a guess and untested :-) But it should give you a clue where to look...

Good luck!
0
 

Author Comment

by:sib_user
ID: 33679986
AmmarR:

I get this error when I attempt your solution:
Msg 102, Level 15, State 1, Line 2
Incorrect syntax near '),
            isnull(left(replace(CTV,'','),2),'.

Khun:

Your give the error:
Msg 102, Level 15, State 1, Line 2
Incorrect syntax near '1'.
Which seems to refute your assertion that the double quotes is the problem.
0
How Do You Stack Up Against Your Peers?

With today’s modern enterprise so dependent on digital infrastructures, the impact of major incidents has increased dramatically. Grab the report now to gain insight into how your organization ranks against your peers and learn best-in-class strategies to resolve incidents.

 
LVL 15

Expert Comment

by:AmmarR
ID: 33680004
there were 2 commas at the end of the line

try this now
EXEC xp_cmdshell 'bcp "SELECT 
            '1', 
            isnull(left(replace(DISTRICT,'''',''),1),' '),
            isnull(left(replace(CTV,'''',''),2),'  '),
            isnull(left(replace(CTV2,'''','')),'     ')            
FROM [CensusData].[dbo].[MainQuestionnaire$]" queryout "C:\bcptest.txt" -T -c -t -S "MYSERVER"' 

Open in new window

0
 
LVL 8

Expert Comment

by:Knut Hunstad
ID: 33680036
I would start with going to a cmd-shell and try typing (or rather put it into a bat-file so you don't have to retype if it doesn't work):

bcp "SELECT
            '1',
            isnull(left(DISTRICT,1),' '),
            isnull(left(CTV,2),'  '),
            isnull(left(CTV2,5),'     ')            
FROM [CensusData].[dbo].[MainQuestionnaire$]" queryout "C:\bcptest.txt" -T -c -t -S "MYSERVER"

to check that works. Then:

bcp "SELECT
            '1',
            isnull(left(DISTRICT,1),' '),
            isnull(left(CTV,2),'  '),
            isnull(left(CTV2,5),'     ')            
FROM [CensusData].[dbo].[MainQuestionnaire$]" queryout C:\bcptest.txt -T -c -t -S MYSERVER

Should help you detect what the problem really is...
0
 

Author Comment

by:sib_user
ID: 33680180
AmmarR;
Same error.

khun:
Have a look at the attached image.
errors.bmp
0
 
LVL 8

Expert Comment

by:Knut Hunstad
ID: 33680242
You need to have it all on on line. I should have mentioned that, of course, sorry. Right now you sent one command:

bcp "SELECT

which triggered the explanation of the bcp command. Then you sent another command:

'1',

which was sort of difficult to understand :-) Etc. etc.

Put this into a text file you call TestSQL.bat:

bcp "SELECT '1', isnull(left(DISTRICT,1),' '), isnull(left(CTV,2),'  '), isnull(left(CTV2,5),'     ') FROM [CensusData].[dbo].[MainQuestionnaire$]" queryout "C:\bcptest.txt" -T -c -t -S "MYSERVER"

Then just write TestSQL.bat at the command prompt. Then try the same with:

bcp "SELECT '1', isnull(left(DISTRICT,1),' '), isnull(left(CTV,2),'  '), isnull(left(CTV2,5),'     ') FROM [CensusData].[dbo].[MainQuestionnaire$]" queryout C:\bcptest.txt -T -c -t -S MYSERVER
0
 

Author Comment

by:sib_user
ID: 33683484
khun,

Tried that and for some strange reason the server seems to be inaccessible when I run the batch file.

I can't figure it out because it runs well from sql server management studio.
0
 

Accepted Solution

by:
sib_user earned 0 total points
ID: 33683784
Got the answer here: ttp://social.msdn.microsoft.com/Forums/en/transactsql/thread/ff79934d-36c6-4078-8081-5e1f14df82c2

All I had to do was put two single quotes everywhere on quote appeared and make sure that everything is on thesame line.

Thanks very much for your attempts.
0
 

Author Closing Comment

by:sib_user
ID: 34186369
I got the answer on another forum.
0

Featured Post

Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

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

Suggested Solutions

INTRODUCTION: While tying your database objects into builds and your enterprise source control system takes a third-party product (like Visual Studio Database Edition or Red-Gate's SQL Source Control), you can achieve some protection using a sing…
In this article I will describe the Copy Database Wizard method as one possible migration process and I will add the extra tasks needed for an upgrade when and where is applied so it will cover all.
Nobody understands Phishing better than an anti-spam company. That’s why we are providing Phishing Awareness Training to our customers. According to a report by Verizon, only 3% of targeted users report malicious emails to management. With compan…

751 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