Monday, June 1, 2015

Salesforce Lesson 4 - Notable Formula Logic Mistakes

Greetings aspiring Force.com developers,

Something like this does NOT mean anything if included with other AND conditions:
OR  (FieldX <> 'A', 
        FieldX <> 'B'
)

Why?  Because its always going to return true regardless of what FieldX value is.  If the value of FieldX happens to be 'A' its true because then FieldX <> 'B'.  If the value of FieldX happens to be 'B' its true because then FieldX <> 'A'.  If the value of FieldX happens to be 'Z' (or anything else) its true because then FieldX <> 'A'.

OK so don't do that - Im beggin.

Maybe you really want NEITHER value A or B here?  (Thats what I think when I see code like this anyway.)  In that case you want to say:
AND  (FieldX <> 'A', 
        FieldX <> 'B'
)

Although if you had this condition inside another AND condition group, as supposed in my first sentence, then just use:
FieldX <> 'A', 
FieldX <> 'B'

Generally speaking this construct is excessive and more complicated for no reason:
AND(AND(condition1, condition2), condition3)

Simplify to:  AND(condition1, condition2, condition3)

For the developer who needs to expand on a rule it can continue to get more complex so keep it as tight and clean as possible to begin with.  

Friday, March 6, 2015

Salesforce Lesson 3 - Cleaner SFDC Formulas

Have you ever needed to maintain a formula and you look at it and it seems confusing/unmanageable?  Salesforce is a fantastic platform for the non-technical to get into building business rules but it can quickly become a tangle of excess code if this is handled by non-engineer types.  Not all admins are created equal either.  One can learn all the ins and outs of administering an org but really still not be too skilled at the simplicity of clean formulas.

Here's a case of what NOT to do and what TO do...

Lets say, for example, you have the following that Fred the-brilliant-sales-guy-and-aspiring-engineer built as a formula:

OR(
    AND(
        fieldXYZ > 10,
        CONTAINS(fieldABC, 'example1'),
        field123 = 'just another case'
    ),
    AND(
        fieldXYZ = 5,
        CONTAINS(fieldABC, 'example1'),
        field123 = 'just another case'
    ),
    AND(
        fieldXYZ < 3,
        CONTAINS(fieldABC, 'example1'),
        field123 = 'just another case'
    )
)

Ever see something like that?  Its probably cleaner than the average salesperson would develop after all check out that indentation - classic good geek practice for readability.  However thats not much of the crux here. Note the only difference between the multiple nested AND groups is the criteria on fieldXYZ otherwise each is the same test.  This is redundant and can quickly become more so as new criteria might need to be added.

The simplification that works is the following:

AND(
      OR(
        fieldXYZ > 10,
        fieldXYZ = 5,
        fieldXYZ < 3
      ),
      CONTAINS(fieldABC, 'example1'),
      field123 = 'just another case'
)

Thats it!  Isnt that better?  Essentially we need to think of the overarching AND instead of an overarching OR and reverse those then add the OR inside that expresses what was different about each original AND group.

This is a simple case but it applies to any similar situation where you have repeating AND group criteria inside an outer OR group.

Carry on and keep it clean and manageable folks!