FUDforum
Fast Uncompromising Discussions. FUDforum will get your users talking.

Home » Imported messages » comp.lang.php » Storing parsed XML-elements as blobs
Show: Today's Messages :: Polls :: Message Navigator
Switch to threaded view of this topic Create a new topic Submit Reply
Storing parsed XML-elements as blobs [message #174266] Mon, 30 May 2011 06:42 Go to next message
Maccabi is currently offline  Maccabi
Messages: 1
Registered: May 2011
Karma: 0
Junior Member
Hello!

I am looking for an efficient way of storing large amounts of data in
mysql, so that it is quick to access and efficient in store. Im using
PHP.

One idea I am playing with, is parsing (deserializing) the elements
and saving the DOMElements (in their binary existience) as BLOBS to be
retrieved and parsed for different type of contained data when
necessary.

One danger I see is that in this way I am "bound" to a platform. I
guess Java or Perl programs on the same platform, or even PHP program
on a different platform, will not be able to utilize the data (is this
really the case, BTW?).

The question is: is it really as efficient as I imagine it to be?
could the efficiency outweigh the disadvantages?

The alternative is to store the XML element as a serialized string,
deserialize it at retrieve time, and analyzing / extracting /
modifying before re-storing as a string.

Any experience / know-how out there?

Thanks a lot!

Michael
Re: Storing parsed XML-elements as blobs [message #174272 is a reply to message #174266] Mon, 30 May 2011 12:57 Go to previous messageGo to next message
Jerry Stuckle is currently offline  Jerry Stuckle
Messages: 2598
Registered: September 2010
Karma: 0
Senior Member
On 5/30/2011 2:42 AM, Maccabi wrote:
> Hello!
>
> I am looking for an efficient way of storing large amounts of data in
> mysql, so that it is quick to access and efficient in store. Im using
> PHP.
>
> One idea I am playing with, is parsing (deserializing) the elements
> and saving the DOMElements (in their binary existience) as BLOBS to be
> retrieved and parsed for different type of contained data when
> necessary.
>
> One danger I see is that in this way I am "bound" to a platform. I
> guess Java or Perl programs on the same platform, or even PHP program
> on a different platform, will not be able to utilize the data (is this
> really the case, BTW?).
>
> The question is: is it really as efficient as I imagine it to be?
> could the efficiency outweigh the disadvantages?
>
> The alternative is to store the XML element as a serialized string,
> deserialize it at retrieve time, and analyzing / extracting /
> modifying before re-storing as a string.
>
> Any experience / know-how out there?
>
> Thanks a lot!
>
> Michael
>

Impossible to tell from your description. The best way to save data is
almost always based on what the data is.

Personally, I don't save DOM elements or XML in MySQL. I save the data.

--
==================
Remove the "x" from my email address
Jerry Stuckle
JDS Computer Training Corp.
jstucklex(at)attglobal(dot)net
==================
Re: Storing parsed XML-elements as blobs [message #174275 is a reply to message #174272] Mon, 30 May 2011 14:57 Go to previous messageGo to next message
Mathieu Maes is currently offline  Mathieu Maes
Messages: 5
Registered: May 2011
Karma: 0
Junior Member
On 30 mei, 14:57, Jerry Stuckle <jstuck...@attglobal.net> wrote:
> On 5/30/2011 2:42 AM, Maccabi wrote:
>
>
>
>
>
>
>
>
>
>> Hello!
>
>> I am looking for an efficient way of storing large amounts of data in
>> mysql, so that it is quick to access and efficient in store. Im using
>> PHP.
>
>> One idea I am playing with, is parsing (deserializing) the elements
>> and saving the DOMElements (in their binary existience) as BLOBS to be
>> retrieved and parsed for different type of contained data when
>> necessary.
>
>> One danger I see is that in this way I am "bound" to a platform. I
>> guess Java or Perl programs on the same platform, or even PHP program
>> on a different platform, will not be able to utilize the data (is this
>> really the case, BTW?).
>
>> The question is: is it really as efficient as I imagine it to be?
>> could the efficiency outweigh the disadvantages?
>
>> The alternative is to store the XML element as a serialized string,
>> deserialize it at retrieve time, and analyzing / extracting /
>> modifying before re-storing as a string.
>
>> Any experience / know-how out there?
>
>> Thanks a lot!
>
>> Michael
>
> Impossible to tell from your description.  The best way to save data is
> almost always based on what the data is.
>
> Personally, I don't save DOM elements or XML in MySQL.  I save the data..
>
> --
> ==================
> Remove the "x" from my email address
> Jerry Stuckle
> JDS Computer Training Corp.
> jstuck...@attglobal.net
> ==================

Hi Michael,

Everything depends on how you want to use the data. Storing XML or
serialized objects in a database may result in certain limitations,
ie. if you want to perform queries on the data.

Serializing may not be a good idea if the data needs to be available
from different platforms.


Kind regards,
Mathew
Re: Storing parsed XML-elements as blobs [message #174279 is a reply to message #174266] Mon, 30 May 2011 18:10 Go to previous message
Axel Schwenke is currently offline  Axel Schwenke
Messages: 2
Registered: May 2011
Karma: 0
Junior Member
Maccabi <norway(dot)maccabi(at)gmail(dot)com> wrote:
>
> I am looking for an efficient way of storing large amounts of data in
> mysql, so that it is quick to access and efficient in store.

What is "large amount"? Access based on what?

> One idea I am playing with, is parsing (deserializing) the elements
> and saving the DOMElements (in their binary existience) as BLOBS to be
> retrieved and parsed for different type of contained data when
> necessary.

Yes, this can be done.

> One danger I see is that in this way I am "bound" to a platform. I
> guess Java or Perl programs on the same platform, or even PHP program
> on a different platform, will not be able to utilize the data (is this
> really the case, BTW?).

What do you mean? A BLOB is a BLOB is a BLOB. Its an array of bytes,
in most client programming languages represented as binary string.
It does not matter what languange or platform that is.

> The question is: is it really as efficient as I imagine it to be?

It depends on what you intend to do with the data.

> The alternative is to store the XML element as a serialized string,
> deserialize it at retrieve time, and analyzing / extracting /
> modifying before re-storing as a string.

From the database point of view this is not different from storing
the binary representation. A BLOB is an opaque object to MySQL.
Just like a XML lump in textual representation. Of course there
are some XML functions which work on strings only. RTFM!

But if we talk of "efficient" in relation to RDBMS, and specifically
MySQL, then storing XML in a BLOB is not much different than storing
it in a file. Accessing rows based on content (say: matching an XPATH
expression) will be painfully slow because it does a table scan.
Things get better when you extract the data you want to use to locate
certain XML fragments and store it in separate columns (with an index).

But overall "XML" and "RDBMS" are pretty orthogonal concepts. RDBMS
operate efficiently on data with a fixed record structure. XML is the
idea of a highly flexible record structure. No good match.


XL
  Switch to threaded view of this topic Create a new topic Submit Reply
Previous Topic: a more elegant way?
Next Topic: Print preview in php
Goto Forum:
  

-=] Back to Top [=-
[ Syndicate this forum (XML) ] [ RSS ]

Current Time: Fri Nov 22 14:53:23 GMT 2024

Total time taken to generate the page: 0.03321 seconds