473,757 Members | 2,284 Online
Bytes | Software Development & Data Engineering Community
+ Post

Home Posts Topics Members FAQ

MYSQL CONSOLIDATION

Can these lines of sql statements be consolidated into one sql statement
(possibly using reg exps??)

BEGIN CODE
+++++++++++++++ +++++++++++++++ +++++++++++++++ +++++++++++++++ ++++++++++++
Update applications Set news_article = replace(news_ar ticle, '<FONT
face="Times New Roman" color=#000000 size=3>', '');
Update applications Set news_article = replace(news_ar ticle, '<P
class=MsoNormal style="MARGIN: 0cm 0cm 0pt">', '');
Update applications Set news_article = replace(news_ar ticle,
'<?xml:namespac e prefix = o ns = "urn:schema s-microsoft-com:office:offi ce"
/>', '');
Update applications Set news_article = replace(news_ar ticle, '<o:p>', '');
Update applications Set news_article = replace(news_ar ticle, '</o:p>', '');
Update applications Set news_article = replace(news_ar ticle, '</P>', '');
Update applications Set news_intro = replace(news_in tro, '<FONT face="Times
New Roman" color=#000000 size=3>', '');
Update applications Set news_intro = replace(news_in tro, '<P class=MsoNormal
style="MARGIN: 0cm 0cm 0pt">', '');
Update applications Set news_intro = replace(news_in tro, '<?xml:namespac e
prefix = o ns = "urn:schema s-microsoft-com:office:offi ce" />', '');
Update applications Set news_intro = replace(news_in tro, '<o:p>', '');
Update applications Set news_intro = replace(news_in tro, '</o:p>', '');
Update applications Set news_intro = replace(news_in tro, '</P>', '');
Update applications Set news_article = replace(news_ar ticle, '<SPAN lang=FR
style="FONT-SIZE: 10pt; COLOR: black; FONT-FAMILY: Arial; mso-ansi-language:
FR">', '');
Update applications Set news_article = replace(news_ar ticle, '<SPAN lang=FR
style="COLOR: black; mso-ansi-language: FR">', '');
Update applications Set news_article = replace(news_ar ticle, '</SPAN>', '');
Update applications Set news_article = replace(news_ar ticle, '<FONT
color=#000000>' , '');
Update applications Set news_article = replace(news_ar ticle, '</FONT>', '');
Update applications Set news_article = replace(news_ar ticle, '<SPAN lang=FR
style="FONT-SIZE: 10pt; COLOR: black; FONT-FAMILY: Arial; mso-ansi-language:
FR">', '');
Update applications Set news_article = replace(news_ar ticle, '<SPAN lang=FR
style="COLOR: black; mso-ansi-language: FR">', '');
Update applications Set news_article = replace(news_ar ticle, '</SPAN>', '');
Update applications Set news_article = replace(news_ar ticle, '<FONT
color=#000000>' , '');
Update applications Set news_article = replace(news_ar ticle, '</FONT>', '');
Update applications Set news_intro = replace(news_in tro, '<SPAN lang=FR
style="FONT-SIZE: 10pt; COLOR: black; FONT-FAMILY: Arial; mso-ansi-language:
FR">', '');
Update applications Set news_intro = replace(news_in tro, '<SPAN lang=FR
style="COLOR: black; mso-ansi-language: FR">', '');
Update applications Set news_intro = replace(news_in tro, '</SPAN>', '');
Update applications Set news_intro = replace(news_in tro, '<FONT
color=#000000>' , '');
Update applications Set news_intro = replace(news_in tro, '</FONT>', '');

+++++++++++++++ +++++++++++++++ +++++++++++++++ +++++++++++++++
END CODE

Many Thanks


Jul 20 '05 #1
3 1672
Can these lines of sql statements be consolidated into one sql statement
(possibly using reg exps??)

BEGIN CODE
+++++++++++++++ +++++++++++++++ +++++++++++++++ +++++++++++++++ ++++++++++++
Update applications Set news_article = replace(news_ar ticle, '<FONT
Update applications Set news_intro = replace(news_in tro, '</SPAN>', ''); [...] Update applications Set news_intro = replace(news_in tro, '<FONT
color=#000000>' , '');
Update applications Set news_intro = replace(news_in tro, '</FONT>', '');

+++++++++++++++ +++++++++++++++ +++++++++++++++ +++++++++++++++
END CODE


Can't you pre-process your field -to remove the Html tags- before inserting
it to the DB?. I'm sure you'll find a library to handle the Html to Text
conversion.

The method you're using is probably slower, and surely, more likely to
produce errors. What if you have:
"<FONT color=#000000>" in your html (double space between FONT and color)?
The replacement won't be done.
Jul 20 '05 #2
Craig Keightley wrote:
Can these lines of sql statements be consolidated into one sql statement
(possibly using reg exps??)

BEGIN CODE
+++++++++++++++ +++++++++++++++ +++++++++++++++ +++++++++++++++ ++++++++++++
Update applications Set news_article = replace(news_ar ticle, '<FONT
face="Times New Roman" color=#000000 size=3>', '');
Update applications Set news_article = replace(news_ar ticle, '<P
class=MsoNormal style="MARGIN: 0cm 0cm 0pt">', '');

....

MySQL supports a regular expression matching predicate, but is not a
substitution function. See http://dev.mysql.com/doc/mysql/en/Regexp.html.

I would solve this not in SQL, but in code. That is, write an
application that reads the values from your `applications` table,
performs the substitutions based on regular expressions, and then if any
substitutions were made, updates that record.

run query SELECT PrimaryKeyField , news_article from applications
loop over result set
{
loop over your list of patterns
{
s/pattern//, check for success
}
if any substitutions succeeded then
{
update application set news_article = ?
where PrimaryKeyField = ?
}
}

This isn't a one-line solution either, but you have more flexibility
with regular expressions, as you pointed out. And putting it into a
script might allow you to maintain the list of patterns more easily.

Don't break your back trying to turn every database task into a single
SQL statement. Sometimes it's better just to get it done!

Regards,
Bill K.
Jul 20 '05 #3
Combined it into one big ugly query by nesting replacements (removed some repeated replacements):
Update applications Set
news_article =
replace(
replace(
replace(
replace(
replace(
replace(
replace(
replace(
replace(
replace(
replace(
news_article,
'<?xml:namespac e prefix = o ns = "urn:schema s-microsoft-com:office:offi ce" />', '' ),
'<P class=MsoNormal style="MARGIN: 0cm 0cm 0pt">', '' ),
'</P>', ''),
'<o:p>', ''),
'</o:p>', ''),
'<FONT face="Times New Roman" color=#000000 size=3>', '' ),
'<FONT color=#000000>' , ''),
'</FONT>', ''),
'<SPAN lang=FR style="FONT-SIZE: 10pt; COLOR: black; FONT-FAMILY: Arial; mso-ansi-language: FR">', ''),
'<SPAN lang=FR style="COLOR: black; mso-ansi-language: FR">', ''),
'</SPAN>', ''),
news_intro =
replace(
replace(
replace(
replace(
replace(
replace(
replace(
replace(
replace(
replace(
replace(
news_intro,
'<?xml:namespac e prefix = o ns = "urn:schema s-microsoft-com:office:offi ce" />', ''),
'<FONT face="Times New Roman" color=#000000 size=3>', ''),
'<FONT color=#000000>' , ''),
'</FONT>', ''),
'<P class=MsoNormal style="MARGIN: 0cm 0cm 0pt">', ''),
'</P>', ''),
'<o:p>', ''),
'</o:p>', ''),
'<SPAN lang=FR style="FONT-SIZE: 10pt; COLOR: black; FONT-FAMILY: Arial; mso-ansi-language: FR">', ''),
'<SPAN lang=FR style="COLOR: black; mso-ansi-language: FR">', ''),
'</SPAN>', '');
You may also want to do this by PHP, so check "strip_tags " function.

Hilarion
Jul 20 '05 #4

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

2
10284
by: francescomoi | last post by:
Hi. I'm trying to build 'MySQL-python-1.2.0' on my Linux FC2: ---------------------------------- # export PATH=$PATH:/usr/local/mysql/bin/ # export mysqlclient=mysqlclient_r # python setup.py clean # python setup.py build running build running build_py
0
3316
by: Randell D. | last post by:
Folks, I have installed MySQL v4 (client, server and development rpm's). I've tried and failed to use the recommended mysqladmin to set a root password after the installation (I have another post open on the MySQL newsgroup about this). I'm attempting an alternative solution and using webmin (www.webmin.com) to create/manage access to my databases. Webmin reports "Warning: The Perl module DBD::mysql is not installed on your system, so...
0
6686
by: Donald Tyler | last post by:
Then the only way you can do it that I can think of is to write a PHP script to do basically what PHPMyAdmin is trying to do but without the LOCAL in there. However to do that you would need to be able to place the PHP file on the server, and I guess you probably can't do that either. Talk about catch 22... The only other way I can think of is to install MySQL on a machine you control, then import the data there using the method I...
4
1305
by: mikey | last post by:
Hi all, I'm having great problems trying to install the latest MySQl RPM package onto my Red Hat Linux OS. There is already MySQL v 3.0 pre-installed with the RH Linux distribution disk but I can not seem to get any of the functions working on it. So I have now dopwnloaded the latest version hoping that this will fix the error. I have managed to install the MySQL-shared-compat-4.0.1-0.i386.rpm but
0
3948
by: Mike Chirico | last post by:
Interesting Things to Know about MySQL Mike Chirico (mchirico@users.sourceforge.net) Copyright (GPU Free Documentation License) 2004 Last Updated: Mon Jun 7 10:37:28 EDT 2004 The latest version of this document can be found at: http://prdownloads.sourceforge.net/souptonuts/README_mysql.txt?download
2
2905
by: trihanhcie | last post by:
I m currently working on a Unix server with a fedora 3 as an os My current version of mysql is 3.23.58. I'd like to upgrade the version to 5.0.18. After downloading from MYSQL.COM the package on the site, I made : rpm -i MySQL-server-5.0.18-0.i386.rpm then i have errors that relate to many conflicts. I cannot figure out why -and- cannot upgrade. Please Help !
1
3227
by: manish deshpande | last post by:
Hi, When i'm installing MySQL-server-standard-5.0.24a-0.rhel3.i386.rpm by the following command: rpm -i MySQL-server-standard-5.0.24a-0.rhel3.i386.rpm the following error is being shown: warning: MySQL-server-standard-5.0.24a-0.rhel3.i386.rpm: V3 DSA signature: NOKEY, key ID 5072e1f5 file /etc/my.cnf from install of MySQL-server-standard-5.0.24a-0.rhel3 conflicts with file from package mysql-3.23.58-1 file...
10
1718
by: bobtehdog | last post by:
Column Consolidation. My problem is this. I have to sort each of the def1-def23 columns from the old table into the def1-def6 columns from the new table preserving the other data in the records. So basically, i have 23 categories that I have to sort into 6 broader or more general categories. I have tried updating/appending the data in the query design view, but I end up with syntactic errors every time due to my lack of knowledge. Below...
3
8831
by: menzies | last post by:
Hi, I"m new to this forum, but I have been trying all day to install DBD::mysql onto my Intel MacBook. I've read lots of forums pages and none have gotten me to a successful 'make test' or a successful 'sudo make install.' Before every attempt I even do a sudo make distclean to make sure I haven't gotten things mucked up from a prior attempt. OS: Mac OS X 10.4.10 MySQL: v5.0.41 for Mac OSX-i686 DBI: v1.58 (installed fine using CPAN)...
0
10069
Oralloy
by: Oralloy | last post by:
Hello folks, I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>". The problem is that using the GNU compilers, it seems that the internal comparison operator "<=>" tries to promote arguments from unsigned to signed. This is as boiled down as I can make it. Here is my compilation command: g++-12 -std=c++20 -Wnarrowing bit_field.cpp Here is the code in...
1
9884
by: Hystou | last post by:
Overview: Windows 11 and 10 have less user interface control over operating system update behaviour than previous versions of Windows. In Windows 11 and 10, there is no way to turn off the Windows Update option using the Control Panel or Settings app; it automatically checks for updates and installs any it finds, whether you like it or not. For most users, this new feature is actually very convenient. If you want to control the update process,...
0
9735
tracyyun
by: tracyyun | last post by:
Dear forum friends, With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each protocol has its own unique characteristics and advantages, but as a user who is planning to build a smart home system, I am a bit confused by the choice of these technologies. I'm particularly interested in Zigbee because I've heard it does some...
1
7285
isladogs
by: isladogs | last post by:
The next Access Europe User Group meeting will be on Wednesday 1 May 2024 starting at 18:00 UK time (6PM UTC+1) and finishing by 19:30 (7.30PM). In this session, we are pleased to welcome a new presenter, Adolph Dupré who will be discussing some powerful techniques for using class modules. He will explain when you may want to use classes instead of User Defined Types (UDT). For example, to manage the data in unbound forms. Adolph will...
0
6556
by: conductexam | last post by:
I have .net C# application in which I am extracting data from word file and save it in database particularly. To store word all data as it is I am converting the whole word file firstly in HTML and then checking html paragraph one by one. At the time of converting from word file to html my equations which are in the word document file was convert into image. Globals.ThisAddIn.Application.ActiveDocument.Select();...
0
5324
by: adsilva | last post by:
A Windows Forms form does not have the event Unload, like VB6. What one acts like?
1
3828
by: 6302768590 | last post by:
Hai team i want code for transfer the data from one system to another through IP address by using C# our system has to for every 5mins then we have to update the data what the data is updated we have to send another system
3
3395
muto222
by: muto222 | last post by:
How can i add a mobile payment intergratation into php mysql website.
3
2697
bsmnconsultancy
by: bsmnconsultancy | last post by:
In today's digital era, a well-designed website is crucial for businesses looking to succeed. Whether you're a small business owner or a large corporation in Toronto, having a strong online presence can significantly impact your brand's success. BSMN Consultancy, a leader in Website Development in Toronto offers valuable insights into creating effective websites that not only look great but also perform exceptionally well. In this comprehensive...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.