PDA

View Full Version : Hardcoding in PHP versus SQL


mihai11
08-02-2007, 12:30 PM
Hi,

I have a list of about 10 categories that I need to display. Right now I have the categories in the database and I am using 1 SQL query to get them. I am thinking that I can hard-code the list of categories in PHP in order to avoid quering the database. The down side of this is that I need to update the list of categories in 2 places (in the database and in the PHP file) if I choose to add more categories in the future. The "bright side" of the "downside" is that the list of categories will be updated VERY rarely (possibly never).

What do you think of this ? Should I hard-code in PHP ?

Regards,
Razvan M.

EnIgMa1234
08-02-2007, 01:22 PM
One query isn't much of a differance if there's only 10 results. I'd go with SQL but thats just me.

Marco van Herwaarden
08-02-2007, 01:30 PM
You could consider storing the categories also as a serialised array in the datastore table. This would reduce the number of extra queries to 1 (which often can be combined with reading other datastore values).

mihai11
08-02-2007, 01:37 PM
You could consider storing the categories also as a serialised array in the datastore table. This would reduce the number of extra queries to 1 (which often can be combined with reading other datastore values).

Hmm.... it is the first time that I look at the datastore table. Can you give me more information about it ? What is its purpose ? Maybe you have a link with relevant information.

Since I am not using datastore values anywhere else in my mod there is no advantage from this point of view: I mean, I am already using just 1 query to retrieve the results.

One more question: how do I serialize values to the datastore ? Is there some VB class to do this ?

One query isn't much of a differance if there's only 10 results. I'd go with SQL but thats just me.

The problem is that the page that requires this query has many options (besides categories) and for each option I will need to fire this query. There will be many views ...

Maybe I should make the table storing this data of type MEMORY. Since it is very small there should be no problem here. Currently the storage engine is INNODB.

Marco van Herwaarden
08-02-2007, 01:54 PM
An in MEMORY (HEAP) table is cleared on each restart of the MySQL server and not suitable for permanent storage (hence why vB only uses HEAP for session tables).

You can find various articles that include information on how to use the datastore, one of them: Cache System Explanation (datastore) (https://vborg.vbsupport.ru/showthread.php?t=110628&highlight=datastore)

PS Using the datastore can reduce the number of queries as vBulletin already read all needed rows from the table.

mihai11
08-02-2007, 05:39 PM
An in MEMORY (HEAP) table is cleared on each restart of the MySQL server and not suitable for permanent storage (hence why vB only uses HEAP for session tables).

You can find various articles that include information on how to use the datastore, one of them: Cache System Explanation (datastore) (https://vborg.vbsupport.ru/showthread.php?t=110628&highlight=datastore)

PS Using the datastore can reduce the number of queries as vBulletin already read all needed rows from the table.

What you suggested is the BEST solution. The relevant part is this:

So instead of running a query everytime you want to get the drop down information, you just get it from the datastore and save that query.


Exactly what I was looking for. Thank you.