Copied to clipboard

Flag this post as spam?

This post will be reported to the moderators as potential spam to be looked at


  • Nilay 8 posts 100 karma points
    Jul 21, 2023 @ 01:41
    Nilay
    0

    Member picker performance issue

    Hello Everyone,

    I am having performance when using member picker and checking conditions, its hitting Database and CPU goes 100 %,

      var site2 = Model.Root();    
      var attendeesByUser = site2.Descendants<Attendee>().Where(x => x.Member?.Id == currMemberId).OrderBy(x => x.StartDate);
    

    in above code Member is Member picker field. When I use above code, it hits Database and CPU goes 100 %,

    If I remove that condition its very quick

    var site2 = Model.Root();      
    var attendeesByUser = site2.Descendants<Attendee>().OrderBy(x => x.StartDate);
    

    .Member returns Ipublishcontent then why it would go to DB to fetch content ?

  • Marc Goodson 2157 posts 14431 karma points MVP 9x c-trib
    Jul 22, 2023 @ 17:14
    Marc Goodson
    100

    Hi Nilay

    When you access properties from IPublishedContent or Modelsbuilder you are not accessing the raw data stored for that property.

    Instead a 'PropertyValueConverter' is run (which is specific for each type of property) to return a helpful friendly object to use in your templates.

    Your MemberPicker will be storing the unique id of the picked member, but your generated Model will be running that through a PropertyValueConverter to give you a representation of the picked item in a familiar shape, eg IPublishedContent - but I don't think Member data is fully stored in the PublishedCache, so might be hitting the database to get the full information of the picked member... to construct the IPublishedContent representation and it will be doing it for every descendant document!

    But in this querying context you do not need the 'Member' representation in order to compare Ids...

    ... So I think you could work around this using the raw stored value for the property, which I think you can access like so:

    var site2 = Model.Root();    
      var attendeesByUser = site2.Descendants<Attendee>().Where(x => x.GetProperty("member")..GetSourceValue() == currMemberId).OrderBy(x => x.StartDate);
    

    where "member" is the alias of the picker...

    ... I think ... !

    regards

    Marc

  • Nilay 8 posts 100 karma points
    Jul 24, 2023 @ 10:35
    Nilay
    0

    Hi Marc,

    Thanks for guiding me to the right direction.

    I have to tweak the code to make it work but your solution gave me righ direction

    Thanks

Please Sign in or register to post replies

Write your reply to:

Draft