Important

You are browsing the documentation for version 4.2 of OroCommerce, OroCRM and OroPlatform, which is no longer maintained. Read version 5.1 (the latest LTS version) of the Oro documentation to get up-to-date information.

See our Release Process documentation for more information on the currently supported and upcoming releases.

ORM Datasource

This datasource provides an adapter to allow accessing data from the doctrine ORM using the doctrine query builder. You can configure a query using the query param under the source tree. This query will be converted via YamlConverter to doctrine QueryBuilder object.

Example

datagrids:
    DATAGRID_NAME_HERE:
        source:
            type: orm
            query:
                select:
                    - email.id
                    - email.subject
                from:
                    - { table: Oro\Bundle\EmailBundle\Entity\Email, alias: email }

Important Notes

By default, all datagrids that use ORM datasource are marked by the HINT_PRECISE_ORDER_BY query hint. This guarantees that rows are sorted the same way independently of the state of SQL server and the values of OFFSET and LIMIT clauses. More details are available in the Queries Limits section of PostgreSQL documentation.

If you need to disable this behavior for your datagrid, use the following configuration:

datagrids:
    DATAGRID_NAME_HERE:
        source:
            type: orm
            query:
                ...
            hints:
                - { name: HINT_PRECISE_ORDER_BY, value: false }

How to

Modify Query Configuration from PHP Code

You can modify query configuration from PHP code, for example from the datagrid extensions or listeners. This can be done using OrmQueryConfiguration class. To get an instance of this class, use the getOrmQuery method of DatagridConfiguration. For example:

$query = $config->getOrmQuery();
$rootAlias = $query->getRootAlias();
$query->addSelect($rootAlias . '.myField');

In additional to query modification methods, the OrmQueryConfiguration contains several useful methods like:

  • getRootAlias() - Returns the FIRST root alias of the query.

  • getRootEntity($entityClassResolver = null, $lookAtExtendedEntityClassName = false) - Returns the FIRST root entity of the query.

  • findRootAlias($entityClass, $entityClassResolver = null) - Tries to find the root alias for the given entity.

  • getJoinAlias($join, $conditionType = null, $condition = null) - Returns an alias for the given join. If the query does not contain the specified join, its alias will be generated automatically. This might be helpful if you need to get an alias to extended association that will be joined later.

  • convertAssociationJoinToSubquery($joinAlias, $columnAlias, $joinEntityClass) - Converts an association based join to a subquery. This can be helpful in case of performance issues with a datagrid.

  • convertEntityJoinToSubquery($joinAlias, $columnAlias) - Converts an entity based join to a subquery. This can be helpful in case of performance issues with a datagrid.

Example of convertAssociationJoinToSubquery usage in a datagrid listener:

public function onPreBuild(PreBuild $event)
{
    $config = $event->getConfig();
    $parameters = $event->getParameters();

    $filters = $parameters->get(OrmFilterExtension::FILTER_ROOT_PARAM, []);
    $sorters = $parameters->get(OrmSorterExtension::SORTERS_ROOT_PARAM, []);
    if (empty($filters['channelName']) && empty($sorters['channelName'])) {
        $config->getOrmQuery()->convertAssociationJoinToSubquery(
            'g',
            'groupName',
            'Acme\Bundle\AppBundle\Entity\UserGroup'
        );
    }
}

The original query:

query:
    select:
        - g.name as groupName
    from:
        - { table: Acme\Bundle\AppBundle\Entity\User, alias: u }
    join:
        left:
            - { join: u.group, alias: g }

The converted query:

query:
    select:
        - (SELECT g.name FROM Acme\Bundle\AppBundle\Entity\UserGroup AS g WHERE g = u.group) as groupName
    from:
        - { table: Acme\Bundle\AppBundle\Entity\User, alias: u }

Please investigate this class to find out all other features.

Add Query Hints

The following example shows how Doctrine query hints can be set:

datagrids:
    DATAGRID_NAME_HERE:
        source:
            type: orm
            query:
                select:
                    - partial g.{id, label}
                from:
                    - { table: Oro\Bundle\ContactBundle\Entity\Group, alias: g }
            hints:
                - HINT_FORCE_PARTIAL_LOAD

If you need to set the hint’s value, use the following syntax:

datagrids:
    DATAGRID_NAME_HERE:
        source:
            type: orm
            query:
                select:
                    - c
                from:
                    - { table: Oro\Bundle\ContactBundle\Entity\Contact, alias: c }
                join:
                    left:
                        - { join: c.addresses, alias: address, conditionType: WITH, condition: 'address.primary = true' }
                        - { join: address.country, alias: country }
                        - { join: address.region, alias: region }
            hints:
                - { name: HINT_CUSTOM_OUTPUT_WALKER, value: Gedmo\Translatable\Query\TreeWalker\TranslationWalker }

Please keep in mind that ORM datasource uses Query Hint Resolver service to handle hints. If you create your own query walker and wish to use it in a grid, register it in the Query Hint Resolver. For example, hint HINT_TRANSLATABLE is registered as an alias for the translation walker and as result the following configurations are equal:

hints:
    - { name: HINT_CUSTOM_OUTPUT_WALKER, value: Gedmo\Translatable\Query\TreeWalker\TranslationWalker }

hints:
    - HINT_TRANSLATABLE

Hint

See Resolve ORM Query Hints for more information.