Solved

SQL Management Studio 2012 - replacing carriage returns

Posted on 2013-12-19
3
1,768 Views
Last Modified: 2013-12-23
I'm running into the issue with a SQL user where data copied from the SQL Management Studio 2012 query results tab and then pasted into Excel results in a bunch of carriage return lines and messes up the paste in Excel.

The "Comments" column in particular has this problem with carriage returns.

Where should the statement in SQL go to get rid of the carriage returns to result in a single-line of text paste to Excel when copied from SQL Management Studio query Results tab?

select 
AssetID,
Category,
EnteredBy,
REPLACE(Text,'"',' ') As Comment,
REPLACE(text, CHAR(13) + CHAR(10), ', '),

Number As CommentNumber,
Max(Date) As CommentDate,
de.NAME_SLS_SPCLST,
de.NAME_SLS_SPCLST_MGR,
de.NAME_RPR_SPCLST,
de.STGY_VAL,
DE.DII,
DE.FLAG_CMPLX_TTL_ACTIVE,
DE.DT_FST_STR_APPRD
--COUNT(Text) As DubCheckByCommentDate
From client.hsc.Comments as C
Left Join
ckuebt.dbo.ImportData_LastImport de
--client.dbo.Inventory de

ON
c.AssetID = de.ID_AST
Where 
--Importid = 8224 AND
Category like 'Iam%'
AND
c.Date = 
       (Select 
              MAX(Date)
       From client.hsc.Comments
       Where Category like 'Iam%'
                     and 
                AssetID = c.AssetID
       Group By AssetID
       )

              --and
              --AssetID = 662438
              and
              Number = (Select
MAX(Number)from client.hsc.Comments
                     where Category like 'Iam%'
                     
                     and AssetID = c.AssetID
                     group by AssetID
                     
              )
              and
              AssetID IN (
675206,
692788,
710061,
779368,
1102107


                                  )

                     
Group By AssetID, Category, EnteredBy, text,Number,de.NAME_SLS_SPCLST,
de.NAME_SLS_SPCLST_MGR,
de.NAME_RPR_SPCLST,
de.STGY_VAL,
DE.DII,
DE.FLAG_CMPLX_TTL_ACTIVE,
DE.DT_FST_STR_APPRD



Order By AssetID

 
----------------------second filter pull-----------------------------------

 

Open in new window

0
Comment
Question by:garryshape
3 Comments
 
LVL 9

Assisted Solution

by:QuinnDex
QuinnDex earned 100 total points
ID: 39731352
sometimes you dont find both char(13) and Char(10) this will stop the replace from finding a match.

try the following if that doesnt work change it to char(13)

select 
AssetID,
Category,
EnteredBy,
REPLACE(Text,'"',' ') As Comment,
REPLACE(text, CHAR(10), ', '),

Number As CommentNumber,
Max(Date) As CommentDate,
de.NAME_SLS_SPCLST,
de.NAME_SLS_SPCLST_MGR,
de.NAME_RPR_SPCLST,
de.STGY_VAL,
DE.DII,
DE.FLAG_CMPLX_TTL_ACTIVE,
DE.DT_FST_STR_APPRD
--COUNT(Text) As DubCheckByCommentDate
From client.hsc.Comments as C
Left Join
ckuebt.dbo.ImportData_LastImport de
--client.dbo.Inventory de

ON
c.AssetID = de.ID_AST
Where 
--Importid = 8224 AND
Category like 'Iam%'
AND
c.Date = 
       (Select 
              MAX(Date)
       From client.hsc.Comments
       Where Category like 'Iam%'
                     and 
                AssetID = c.AssetID
       Group By AssetID
       )

              --and
              --AssetID = 662438
              and
              Number = (Select
MAX(Number)from client.hsc.Comments
                     where Category like 'Iam%'
                     
                     and AssetID = c.AssetID
                     group by AssetID
                     
              )
              and
              AssetID IN (
675206,
692788,
710061,
779368,
1102107


                                  )

                     
Group By AssetID, Category, EnteredBy, text,Number,de.NAME_SLS_SPCLST,
de.NAME_SLS_SPCLST_MGR,
de.NAME_RPR_SPCLST,
de.STGY_VAL,
DE.DII,
DE.FLAG_CMPLX_TTL_ACTIVE,
DE.DT_FST_STR_APPRD



Order By AssetID

 
----------------------second filter pull-----------------------------------

 
                                  

Open in new window

0
 
LVL 34

Accepted Solution

by:
James0628 earned 400 total points
ID: 39733486
QuinnDex has a point, but the other thing that I noticed is that you have two separate REPLACE functions, in separate columns.

 You have

REPLACE(Text,'"',' ') As Comment,

 which creates a column named Comment.

 But then you have the CR-LF replace in a separate, unnamed, column:

REPLACE(text, CHAR(13) + CHAR(10), ', '),


 If you want your Comment column to be the result from both REPLACE functions, you can nest them:

REPLACE(REPLACE(Text,'"',' '), CHAR(13) + CHAR(10), ', ') As Comment,


 James
0
 

Author Comment

by:garryshape
ID: 39735262
Thanks guys I haven't tried yet but will within the next 1 - 2 days and report back.
0

Featured Post

Enabling OSINT in Activity Based Intelligence

Activity based intelligence (ABI) requires access to all available sources of data. Recorded Future allows analysts to observe structured data on the open, deep, and dark web.

Join & Write a Comment

Jaspersoft Studio is a plugin for Eclipse that lets you create reports from a datasource.  In this article, we'll go over creating a report from a default template and setting up a datasource that connects to your database.
Today, still in the boom of Apple, PC's and products, nearly 50% of the computer users use Windows as graphical operating systems. If you are among those users who love windows, but are grappling to keep the system's hard drive optimized, then you s…
Via a live example, show how to setup several different housekeeping processes for a SQL Server.
Viewers will learn how to use the UPDATE and DELETE statements to change or remove existing data from their tables. Make a table: Update a specific column given a specific row using the UPDATE statement: Remove a set of values using the DELETE s…

708 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

Need Help in Real-Time?

Connect with top rated Experts

14 Experts available now in Live!

Get 1:1 Help Now