Log in

View Full Version : The joys of serializing data


filburt1
06-17-2003, 10:00 PM
To serialize a variable or object in PHP means to take the variable or object and convert it to a string that can be stored anywhere, including, relevant to vB, a MySQL database. Later, it can be unserialized, at which point it'll be (nearly) exactly the same as when it was serialized.

An example:

$serialized = serialize($myobject);
.
.
.
$myobjectagain = unserialize($serialized);
$myobjectagain->method();

Remember to addslashes $serialized when making a query because it could contain quotes. Also note that some tiny things can be lost when serializing; namely, internal array pointers, among others.

Reference:
http://www.php.net/serialize
http://www.php.net/unserialize (way faster than serializing)

MUG
06-18-2003, 12:11 AM
Note that you can't serialize resources (such as a mysql connection) so the example posted won't work.

filburt1
06-18-2003, 12:39 AM
The example itself should work, though, because $DB_site is just an object that never stores a result handle (at least not permanently).

MUG
06-18-2003, 12:42 AM
Today at 09:39 PM filburt1 said this in Post #3 (https://vborg.vbsupport.ru/showthread.php?postid=410121#post410121)
The example itself should work, though, because $DB_site is just an object that never stores a result handle (at least not permanently).

One of the variables in $DB_site is $link_id and that can't be serialized. ;)
$query_id can't be serialized either.

In order to run $DB_site->query(), $link_id has to be a valid MySQL connection resource.

filburt1
06-18-2003, 01:03 AM
Oh, good point ;)

But the concept is there ;)

Boofo
02-12-2004, 07:33 AM
Great! A thread on serializing. ;)

I'm just starting to learn this. Maybe you can answer this question, filburt. How do we determine this when making the query for the datstore?

"newusers";s:1:"0";s:14:"getthreadviews";s:1:"0";s:9:

That's a snippet of caode we're using. What are the s:1 and the s:9 (and s:14) for? I know the zero is for the default value. And is there an easier way to list this so it can be added to easily?

Andreas
02-12-2004, 08:41 AM
s(tring):(Length)1:(Value)"0";s(tring):(Length)14:(Value)"getthreadviews";

I'd guess.

Boofo
02-12-2004, 09:49 AM
Why would you need 2 string lengths in there? ;)

Andreas
02-12-2004, 09:59 AM
s:1:"0";s:14:"getthreadviews"

Arn't there two strings - "0" (length 1) and "getthreadviews" (length 14)?

Boofo
02-12-2004, 10:40 AM
Ahhh, ok, now I understand. ;)

Thank you, sir. ;)

futureal
02-12-2004, 04:48 PM
I think the two strings are actually part of a single variable. For example:

s:8:"newusers";s:1:"0";s:14:"getthreadviews";s:1:"0";

This would correspond to a variable called "newusers" with a value of "0" and a variable called "getthreadviews" with a value of "0" as well.

When it is processed by the unserialize(...) function it looks for pairs like this and converts them into PHP variables in an array. So if you called:

$test = unserialize(the above string);

You should then have:

$test[newusers] == 0
$test[getthreadviews] == 0

Hope that helps!

Boofo
02-12-2004, 05:03 PM
Thank you, very much, for the explanation. I'm just now learning about this great function and it's not turning out to be as confusing as I first thought, it seems. It's starting to make some sense to me. ;)

Link14716
02-13-2004, 01:32 AM
Yeah, serializing is way cool. :)

Boofo
02-13-2004, 01:35 AM
I'm having a blast with it. I finished one hack upgrade with it and I'm working on another. Still stumbling and learning, though. ;)

AN-net
04-13-2004, 04:01 PM
when should we really use serialize?

Xenon
04-13-2004, 04:17 PM
when you read out an object very often, but don't change that object very often :)

AN-net
04-13-2004, 04:23 PM
can you give me an example, cause im kinda new to this serialize thingy:)

Boofo
04-13-2004, 06:49 PM
Like my forumhome stats cache hack. It gets read from the cache only every 10 minutes on my site (you can set it to whatvere you want) so it's a great place to store it since the information won't change until it gets updated again. Plus, when you unserialize it (read from the cache) it doesn't produce a query.

kafi
10-05-2007, 07:46 AM
How do I make querry to filter users according their option in multiple profile field option?.

I need to get all users that have choosed any of first five options out of 17? Some of them may have choosed more than 1 otion!
In admincp you can serach users only like this "option1 and option2 and option3..." but I need to search like this "option1 OR option2 OR option3" (which is impossible with admincp).

a:18:{i:0;s:8:"option1";i:1;s:19:"option2";i:2;s:5 :"option3";i:3;s:15:"option4";i:4;s:21:"option5";i :5;s:15:"";i:6;s:16:"option6";i:7;s:17:"option7";i :8;s:10:"option8";i:9;s:18:"option9";i:10;s:8:"opt ion10";i:11;s:15:"option11 ";i:12;s:14:"option12";i:13;s:7:"option13";i:14;s: 7:"option14";i:15;s:20:"option15";i:16;s:22:"optio n16";i:17;s:3:"option17";}

Thanks!!!!!

Andreas
10-05-2007, 08:20 AM
SELECT user.*
FROM user
LEFT JOIN userfield ON (userfield.userid=user.userid)
WHERE (fieldX & 1) OR (fieldx & 2) OR (fieldX & 4)


Alternatively, you could add up the values

SELECT user.*
FROM user
LEFT JOIN userfield ON (userfield.userid=user.userid)
WHERE (fieldX & 7)


This query should be more efficient.

Option 1 = 1
Option 2 = 2
Option 3 = 4
Option 4 = 8
and so on

kafi
04-30-2008, 09:38 AM
Thank you Andreas!

It helped me today again :)

Antivirus
10-25-2010, 06:50 PM
Not to resurrect an old thread, but... I have been storing a lot of serialized data lately, and came across a pretty useful web tool to easily view it when needed. Basically This tool enables you to serialize or unserialize arrays (mainly) with several 'serialization' functions : php serialize, json, yaml, and php var_export.

Supposedly also does following:
•unserialization of broken serialized array (recover / repair "php serialize" arrays)
•deep unserialization of serialized serialisation ! ;) (for php serialize)

http://www.unserialize.net/serialize