Jump to main content Jump to doc navigation

Single Objects

Once you've got an Object, you can change the values of the record by setting fields.

Setting the fields only changes the values in the object, and holds them temporarily in memory until you save the object permanently to the database.

Setting can be done multiple ways.

set

The primary way is via the set method:

$myBox->set('width',10);
$myBox->set('height',4);

set() also takes a 3rd $vType parameter, which is either a string indicating the format of provided value, or a callable function that should be used to set the field value, overriding the default behavior. For example:

/* Set date as an unix timestamp integer rather than a string date */
$myBox->set('birthday',432432543,'integer');

/* Set dimension of box based on width and height via custom function */
function setDim($k,$v,&$obj) {
   $w = $obj->get('width');
   $h = $obj->get('height');
   $dim = $w * $h;
   $obj->set($k,$dim);
}
$myBox->set('dimension','','setDim');

fromArray

Another way Objects can be set in xPDO is through the fromArray() method:

$myBox->fromArray(array(
   'width' => 5,
   'height' => 10,
));

xPDOObject::fromArray takes 5 parameters in total. We've seen the first in use. The second is $keyPrefix, which when set, will strip the passed value from the array you are passing in the first parameter. A good example of this is when passing $_POST vars to an Object:

// Let us say that:
// $_POST = array(
//    'test_w' => 12,
//    'test_h' => 13,
// );
$myBox->fromArray($_POST,'test_');

echo $myBox->get('w'); // prints '12'

The third parameter, $setPrimaryKeys, is a boolean value that defaults to false. When set, it will allow Primary Keys in the object to be set. This is useful for creating new objects that you want to specify the ID of:

$myBox = $xpdo->newObject('Box');
$myBox->fromArray(array(
   'id' => 23,
   'width' => 5,
   'height' => 5,
),'',true);

echo $myBox->get('id'); // prints '23'

The fourth parameter, $rawValues, is set to false by default. If true, the object will set its values without calling set() internally. What does this mean? Well, it means field type validation wont happen; nor will that field be set as 'dirty'.

The fifth parameter, $adhocValues, when true, will automatically set any passed values as object vars, regardless of whether or not they are actually fields in the object. For example:

$myBox->fromArray(array(
  'width' 5',
  'notRealField' => 'boo',
),'',false,false,true);

The last field can be overridden by passing xPDO::OPT_HYDRATE_ADHOC_FIELDS as 'true' into the xPDO config. If that setting is true, the 5th parameter will always be true.

save

This function allows you to save your set fields permanently to the database.

$myBox->save();

This will immediately execute the UPDATE (or CREATE) query that will save the record to the database.

Many objects at once

public function updateCollection($className, array $set, $criteria= null) {

For batch updates, you can use xPDO->updateCollection($className, $setValues, $critera).

The parameters are:

  • $className: the name of the model to update
  • $setValues: an array with key => value pairs of values to set
  • $criteria: an xPDOCritera instance or array representing a condition for which collections need to be updated.

For example:

$modx->updateCollection('modResource', ['published' => true], ['published' => false]);

The number of updated rows will be returned by this method.

Be careful with this method as failing to provide the (right) criteria can cause to impact a lot of rows.