Best practice for comparing product specs

Author Message

Eirik Alfstad Johansen

Thursday 01 April 2004 5:10:06 am

Hi,

What's the best way to store specs for products when these are to be compared?

When I recently created a web site for a our web hosting service, I solved the problem by creating one product class and one product spec class. The product spec class attributes were the name of the spec as well as one attribute for the spec value of each product.

This worked fine since there were only 4 "products" (hosting packages) and new products are rarely added. If new products were to be added, however, one would have to edit the product spec class to add a new attribute. Also, there would be no physical relation between the spec and the product, and one would have to edit each product spec object when adding a product to include the value of the product spec for the new product.

Now I have encountered the same problem yet again with a client site, and I'm looking for suggestions/ideas on how to best store product specs for comparison.

Thanks in advance !

Sincerely,

Eirik Johansen

Sincerely,

Eirik Alfstad Johansen
http://www.netmaking.no/

Alex Jones

Monday 05 April 2004 6:57:47 am

I have been struggling with this idea for close to a year now, and sadly I don't have a very good solution. I tried using a modified Matrix datatype, but that is problematic as I cannot change the name of a spec site-wide, nor can I easily change the order of the specs. After various other tests, I have fallen back on standard Text Lines, which isn't a good solution either, as each product can include 15 specs, thus increasing initial content creation, storage space and display time.

I would love to see a solution to the issue.

Alex

Alex
[ bald_technologist on the IRC channel (irc.freenode.net): #eZpublish ]

<i>When in doubt, clear the cache.</i>

Eirik Alfstad Johansen

Wednesday 07 April 2004 1:58:56 am

Hi Alex,

<i>I have fallen back on standard Text Lines, which isn't a good solution either[...]</i>

Do you mean that you store them as class attributes?

Sincerely,

Eirik Johansen

Sincerely,

Eirik Alfstad Johansen
http://www.netmaking.no/

Bård Farstad

Wednesday 07 April 2004 2:36:07 am

I think that I would have made a new datatype for this where you define the fields to compare at class level and just fill in the values when you edit the object. When you have this as a separate datatype you could design it so it will be simple to compare different products with different values.

I would not serialize this into xml when storing since it will then be hard to do comparison.

I think a new datatype which is designed for this is the best way. I don't see any existing datatypes really fit into this.

--bård

Documentation: http://ez.no/doc

Alex Jones

Wednesday 07 April 2004 7:31:17 am

Eirik, I do indeed store them as a class attribute which is a Text Line.

Bård, that is a good point. When I set up my first site, which was the one with the large amounts of product specifications I wasn't familiar with the system, so that never ocurred to me. I like your idea and may very well use it with the next site I create.

Alex

Alex
[ bald_technologist on the IRC channel (irc.freenode.net): #eZpublish ]

<i>When in doubt, clear the cache.</i>

Powered by eZ Publish™ CMS Open Source Web Content Management. Copyright © 1999-2014 eZ Systems AS (except where otherwise noted). All rights reserved.

eZ debug

Timing: Jan 19 2025 00:20:52
Script start
Timing: Jan 19 2025 00:20:52
Module start 'layout'
Timing: Jan 19 2025 00:20:52
Module start 'content'
Timing: Jan 19 2025 00:20:53
Module end 'content'
Timing: Jan 19 2025 00:20:53
Script end

Main resources:

Total runtime0.7111 sec
Peak memory usage4,096.0000 KB
Database Queries65

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0081 588.0469152.6406
Module start 'layout' 0.00810.0039 740.687539.4766
Module start 'content' 0.01190.6976 780.1641608.5625
Module end 'content' 0.70950.0016 1,388.726616.4375
Script end 0.7111  1,405.1641 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00380.5282160.0002
Check MTime0.00160.2285160.0001
Mysql Total
Database connection0.00080.117510.0008
Mysqli_queries0.642290.3126650.0099
Looping result0.00070.0938630.0000
Template Total0.650191.420.3250
Template load0.00260.364220.0013
Template processing0.647491.046920.3237
Template load and register function0.00010.018310.0001
states
state_id_array0.00190.262110.0019
state_identifier_array0.00240.336320.0012
Override
Cache load0.00230.3171350.0001
Sytem overhead
Fetch class attribute can translate value0.00070.095030.0002
Fetch class attribute name0.00110.154780.0001
XML
Image XML parsing0.00150.205930.0005
class_abstraction
Instantiating content class attribute0.00000.0023100.0000
General
dbfile0.00120.1643290.0000
String conversion0.00000.001440.0000
Note: percentages do not add up to 100% because some accumulators overlap

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1node/view/full.tplfull/forum_topic.tplextension/sevenx/design/simple/override/templates/full/forum_topic.tplEdit templateOverride template
5content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
5content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
5content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 17
 Number of unique templates used: 5

Time used to render debug report: 0.0001 secs