Solved

Find and replace part of a string

Posted on 2011-09-05
12
433 Views
Last Modified: 2012-05-12
Experts-

I have string responses stored in my table.  Some of the responses contain "dbmSnippets" within the response string.  I would like to find all of the dbmSnippets and replace them with \' keeping the rest of the response in tact.  Any suggestion on how to do this would be appreciated.

Thanks
Nick
0
Comment
Question by:nmarano
[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
  • 4
  • 3
12 Comments
 
LVL 10

Accepted Solution

by:
NetExpert-Warszawa earned 400 total points
ID: 36485289
UPDATE tablename SET response = REPLACE(response, 'dbmSnippets', '\') WHERE response LIKE '%dbmSnippets%';
0
 
LVL 2

Author Comment

by:nmarano
ID: 36485343
Thanks Net.

 Will that keep the rest of my string intact?  So if my string looks like,
Yes~I agree that JuliadbmSnippetss quadlateral performance"  Will it simply replace the dbmSnippets to look like...
"Yes~I agree that Julia's quadlateral performance"
0
 
LVL 60

Expert Comment

by:Kevin Cross
ID: 36485387
It looks like the current query is replacing it with a slash '\' -- update the code to be REPLACE(response, 'dbmSnippets', '\'') and it will result in only the dbmSnippets being replaced. The rest of the string will be untouched.
0
Guide to Performance: Optimization & Monitoring

Nowadays, monitoring is a mixture of tools, systems, and codes—making it a very complex process. And with this complexity, comes variables for failure. Get DZone’s new Guide to Performance to learn how to proactively find these variables and solve them before a disruption occurs.

 
LVL 10

Expert Comment

by:NetExpert-Warszawa
ID: 36485391
No, it will not. I have thought you want \, not '.

You need:
UPDATE tablename SET response = REPLACE(response, 'dbmSnippets', "'") WHERE response LIKE '%dbmSnippets%';

WHERE response LIKE '%dbmSnippets%' will look for all rows for which a column response contains dbmSnippets.

REPLACE(response, 'dbmSnippets', "'") will produce a string that will be a content of response with all dbmSnippets replaced with '.

Before you run it over your production table, create a test table and try the query on it.
0
 
LVL 2

Author Comment

by:nmarano
ID: 36485573
Sorry net correct, I want /'
0
 
LVL 10

Expert Comment

by:NetExpert-Warszawa
ID: 36485585
Just put what you want as the third parameter for REPLACE.
0
 
LVL 2

Author Comment

by:nmarano
ID: 36485594
Net, I'm looking for a slash and an apostrophe so the replace will be /'

Thanks
nick
0
 
LVL 10

Expert Comment

by:NetExpert-Warszawa
ID: 36485610
You are not limited to a single character. Try:

UPDATE tablename SET response = REPLACE(response, 'dbmSnippets', "/'") WHERE response LIKE '%dbmSnippets%';
or
UPDATE tablename SET response = REPLACE(response, 'dbmSnippets', '/\'') WHERE response LIKE '%dbmSnippets%';
0
 
LVL 2

Author Comment

by:nmarano
ID: 36485718
Hey Net,

Sorry for the confusion.  So, I'm looking to use \' and not the back slash/.  Now I tested it on a couple of results, but it's taking the dbmSnippets out but only replacing it with a ' instead of \'....

0
 
LVL 60

Assisted Solution

by:Kevin Cross
Kevin Cross earned 100 total points
ID: 36485757
Here is a reference on escaping special characters in MySQL:
http://dev.mysql.com/doc/refman/5.0/en/string-syntax.html

Manual on REPLACE:
http://dev.mysql.com/doc/refman/5.0/en/string-functions.html#function_replace

What you want is:
REPLACE(response, 'dbmSnippets', '\\\'')

Open in new window

0
 
LVL 60

Expert Comment

by:Kevin Cross
ID: 36485764
Please credit, Net, by the way. Just helping you get the understanding you need.
0
 
LVL 2

Author Comment

by:nmarano
ID: 36485813
thank you guys for your help.  Truly appreciated.  Net, thanks for the query, and mwvisa, thanks for the links.
0

Featured Post

Free Tool: ZipGrep

ZipGrep is a utility that can list and search zip (.war, .ear, .jar, etc) archives for text patterns, without the need to extract the archive's contents.

One of a set of tools we're offering as a way to say thank you for being a part of the community.

Question has a verified solution.

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

Popularity Can Be Measured Sometimes we deal with questions of popularity, and we need a way to collect opinions from our clients.  This article shows a simple teaching example of how we might elect a favorite color by letting our clients vote for …
Load balancing is the method of dividing the total amount of work performed by one computer between two or more computers. Its aim is to get more work done in the same amount of time, ensuring that all the users get served faster.
In a recent question (https://www.experts-exchange.com/questions/29004105/Run-AutoHotkey-script-directly-from-Notepad.html) here at Experts Exchange, a member asked how to run an AutoHotkey script (.AHK) directly from Notepad++ (aka NPP). This video…
How to Install VMware Tools in Red Hat Enterprise Linux 6.4 (RHEL 6.4) Step-by-Step Tutorial

696 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