Forums / Developer / Datatype without ezcontnetobject_attribute

Datatype without ezcontnetobject_attribute

Author Message

Gernot Rief

Wednesday 04 May 2005 3:28:34 am

hi!
is it possible to create a datatype without using the ezcontnetobject_attribute table?
e.g. using only ezcontentobject, ...version, ..tree and a table for my data.
reason: my ezcontnetobject_attribute is getting very big and slows down my queries

thx

kracker (the)

Wednesday 04 May 2005 3:54:32 am

not that I've ever seen?

Still I have heard before (in past threads / which I can't seem to find at the moment) that ....

When you really have a lot of attributes per content class, it may be wise to consider breaking the one class into two or more different classes and adding a relationship (related objects perhaps) between the two objects?

still, more information might help understand your situation better ...

- How many attributes do you have in your class
- What are the specs of your web server (memory, cpu, hosting style(dedicated vs vds vs shared vs the rest))

More server power is like throwing hardware at the problem, (which i tend to think (at times) as more cost effective than software) aka you may be pushing the limits not of eZ publish but of eZ publish within the bounds of your current server configuration.

//kracker

Futurama : A Tale of Two Santas

Member since: 2001.07.13 || http://ezpedia.se7enx.com/

Gernot Rief

Wednesday 04 May 2005 4:06:20 am

hi!

we allredy splitted but did not use related objects but used the (now main object) as the parent node for the remaining objects.

our "starting-condition" for ezcontentobject_attributes: 2.500.000 entries
estimatet (with the current handle of attibutes): > 7.000.000 entries

i really need to get rid of them.....

kracker (the)

Wednesday 04 May 2005 4:31:06 am

Gernot,

The Parent / Child breakout is also a good alternative.

I didn't understand this block of your reply.

our "starting-condition" for ezcontentobject_attributes: 2.500.000 entries
estimatet (with the current handle of attibutes): > 7.000.000 entries

So I'm still wondering how many attributes per class you have ( 25, 50, 400 ??)

Knowing how many attributes per class (and what kind of attributes) could help determine the scope of the breakdown.

I wager some attribute types are more performance intensive than simpler attributes (textline vs mult-select)

For reference, you may wish to post the class definition for your class and it's attributes to see just how big of a class this exactly is...

Fyi, exporting your packages via the ezpkg administration is a great way of getting a text output of eZ publish classes.

cheers,
//kracker

Invader Zim - Door to Door

Member since: 2001.07.13 || http://ezpedia.se7enx.com/

Gernot Rief

Wednesday 04 May 2005 5:30:20 am

hi!

explaining the whole class-structure would take some time... ;-)

the two numbers(2.5m, 7m) are: number of entries in ezcontentobject_attribute after an initial import of exisiting data-sets and estimated number of entries in 2 years

now a class example:

-class person:
--attribute my_own_person_datatype (72 fields)
(60.000 persons x 72 attributes:saved me over 4.3m entries in ezcontentobject_attribute)
--8 object_relation_lists (shame on me, but enhanced object relation was not out yet)

some of the object_relation_lists consist of objects which also have object_relation_lists as attributes.

all in all we have 300.000 objects with 2.5m attributes

so my goal is the keep ezcontentobject_attribute as small as possible cause joining and updating in this table is very time-consuming, especially with between 10 and 50 users editing content and therefore: viewcache=disabled

kracker (the)

Thursday 05 May 2005 3:30:23 am

I can relate to your frustration. Sadly this is where I begin to tap out.

I wonder if a more well versed developer or eZ systems team member might comment on possible solutions to your performance problems with large classes and objects.

I still think it's a good that you gave us all a fairly good idea of the scope / size of the situation.

Respectfully,
//kracker

Eyedea & Abilities : Coaches

Member since: 2001.07.13 || http://ezpedia.se7enx.com/

eZ debug

Timing: Jan 18 2025 19:28:00
Script start
Timing: Jan 18 2025 19:28:00
Module start 'content'
Timing: Jan 18 2025 19:28:00
Module end 'content'
Timing: Jan 18 2025 19:28:00
Script end

Main resources:

Total runtime0.9077 sec
Peak memory usage4,096.0000 KB
Database Queries203

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0102 587.8438180.8125
Module start 'content' 0.01020.6744 768.6563587.9844
Module end 'content' 0.68450.2231 1,356.6406341.3672
Script end 0.9076  1,698.0078 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00470.5157210.0002
Check MTime0.00170.1838210.0001
Mysql Total
Database connection0.00110.124310.0011
Mysqli_queries0.810989.33642030.0040
Looping result0.00290.31962010.0000
Template Total0.867795.620.4339
Template load0.00200.224120.0010
Template processing0.865795.376220.4328
Template load and register function0.00020.024810.0002
states
state_id_array0.00340.376010.0034
state_identifier_array0.00160.177320.0008
Override
Cache load0.00180.2021590.0000
Sytem overhead
Fetch class attribute can translate value0.00110.119730.0004
Fetch class attribute name0.00260.284770.0004
XML
Image XML parsing0.00110.117030.0004
class_abstraction
Instantiating content class attribute0.00000.002790.0000
General
dbfile0.00310.3400290.0001
String conversion0.00000.001430.0000
Note: percentages do not add up to 100% because some accumulators overlap

CSS/JS files loaded with "ezjscPacker" during request:

CacheTypePacklevelSourceFiles
CSS0extension/community/design/community/stylesheets/ext/jquery.autocomplete.css
extension/community_design/design/suncana/stylesheets/scrollbars.css
extension/community_design/design/suncana/stylesheets/tabs.css
extension/community_design/design/suncana/stylesheets/roadmap.css
extension/community_design/design/suncana/stylesheets/content.css
extension/community_design/design/suncana/stylesheets/star-rating.css
extension/community_design/design/suncana/stylesheets/syntax_and_custom_tags.css
extension/community_design/design/suncana/stylesheets/buttons.css
extension/community_design/design/suncana/stylesheets/tweetbox.css
extension/community_design/design/suncana/stylesheets/jquery.fancybox-1.3.4.css
extension/bcsmoothgallery/design/standard/stylesheets/magnific-popup.css
extension/sevenx/design/simple/stylesheets/star_rating.css
extension/sevenx/design/simple/stylesheets/libs/fontawesome/css/all.min.css
extension/sevenx/design/simple/stylesheets/main.v02.css
extension/sevenx/design/simple/stylesheets/main.v02.res.css
JS0extension/ezjscore/design/standard/lib/yui/3.17.2/build/yui/yui-min.js
extension/ezjscore/design/standard/javascript/jquery-3.7.0.min.js
extension/community_design/design/suncana/javascript/jquery.ui.core.min.js
extension/community_design/design/suncana/javascript/jquery.ui.widget.min.js
extension/community_design/design/suncana/javascript/jquery.easing.1.3.js
extension/community_design/design/suncana/javascript/jquery.ui.tabs.js
extension/community_design/design/suncana/javascript/jquery.hoverIntent.min.js
extension/community_design/design/suncana/javascript/jquery.popmenu.js
extension/community_design/design/suncana/javascript/jScrollPane.js
extension/community_design/design/suncana/javascript/jquery.mousewheel.js
extension/community_design/design/suncana/javascript/jquery.cycle.all.js
extension/sevenx/design/simple/javascript/jquery.scrollTo.js
extension/community_design/design/suncana/javascript/jquery.cookie.js
extension/community_design/design/suncana/javascript/ezstarrating_jquery.js
extension/community_design/design/suncana/javascript/jquery.initboxes.js
extension/community_design/design/suncana/javascript/app.js
extension/community_design/design/suncana/javascript/twitterwidget.js
extension/community_design/design/suncana/javascript/community.js
extension/community_design/design/suncana/javascript/roadmap.js
extension/community_design/design/suncana/javascript/ez.js
extension/community_design/design/suncana/javascript/ezshareevents.js
extension/sevenx/design/simple/javascript/main.js

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
6content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
6content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
12content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
3content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
1content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 30
 Number of unique templates used: 7

Time used to render debug report: 0.0002 secs