1
0
Fork 0
mirror of synced 2025-04-04 05:43:36 +03:00
Doctrine 2 Object Relational Mapper (ORM)
Find a file
Marco Pivetta ca436f0bae #7527 performance benchmark - verifying performance impact of inferred query parameter types
As an example result:

```
./phpbench.phar run tests/Doctrine/Performance/Query --iterations=50 --revs=50 --report=aggregate
PhpBench 0.15-dev (dcbe193). Running benchmarks.
Using configuration file: /home/ocramius/Documents/doctrine/doctrine2/phpbench.json

\Doctrine\Performance\Query\QueryBoundParameterProcessingBench

    benchExecuteParsedQueryWithInferredParameterTypeI49 P0 	[μ Mo]/r: 643.684 634.664 (μs) 	[μSD μRSD]/r: 17.700μs 2.75%
    benchExecuteParsedQueryWithDeclaredParameterTypeI49 P0 	[μ Mo]/r: 97.673 94.251 (μs) 	[μSD μRSD]/r: 8.259μs 8.46%

2 subjects, 100 iterations, 100 revs, 0 rejects, 0 failures, 0 warnings
(best [mean mode] worst) = 88.460 [370.679 364.458] 127.400 (μs)
⅀T: 37,067.880μs μSD/r 12.980μs μRSD/r: 5.603%
suite: 133f0e30090f815142331ebec6af18241694e7c0, date: 2018-12-19, stime: 10:47:10
+------------------------------------+--------------------------------------------------+--------+--------+------+-----+------------+-----------+-----------+-----------+-----------+----------+--------+-------+
| benchmark                          | subject                                          | groups | params | revs | its | mem_peak   | best      | mean      | mode      | worst     | stdev    | rstdev | diff  |
+------------------------------------+--------------------------------------------------+--------+--------+------+-----+------------+-----------+-----------+-----------+-----------+----------+--------+-------+
| QueryBoundParameterProcessingBench | benchExecuteParsedQueryWithInferredParameterType |        | []     | 50   | 50  | 5,970,568b | 604.680μs | 643.684μs | 634.664μs | 677.640μs | 17.700μs | 2.75%  | 6.59x |
| QueryBoundParameterProcessingBench | benchExecuteParsedQueryWithDeclaredParameterType |        | []     | 50   | 50  | 5,922,424b | 88.460μs  | 97.673μs  | 94.251μs  | 127.400μs | 8.259μs  | 8.46%  | 1.00x |
+------------------------------------+--------------------------------------------------+--------+--------+------+-----+------------+-----------+-----------+-----------+-----------+----------+--------+-------+
```

This indicates that the performance impact for NOT declaring parameter types
explicitly is *MASSIVE*.
2018-12-19 10:52:11 +01:00
bin Use short-array syntax on "bin" directory 2016-12-07 23:34:14 +01:00
docs Merge pull request #7521 from doctrine/update-chat-link 2018-12-12 20:07:31 +00:00
lib/Doctrine/ORM Note: this will still lead to the UnitOfWork#getSingleIdentifierValue() still being 2018-12-16 18:05:02 +01:00
tests #7527 performance benchmark - verifying performance impact of inferred query parameter types 2018-12-19 10:52:11 +01:00
tools/sandbox Use HTTPS endpoint for XML schema location 2018-11-12 11:29:32 +01:00
.gitattributes Add configuration for PHPCS 2017-11-23 11:26:33 +01:00
.gitignore Lock dependencies for Code Quality stage 2018-12-10 13:58:51 +01:00
.gitmodules Removing submodules as of doctrine/doctrine2#570 2013-02-15 18:33:29 +01:00
.scrutinizer.yml Use new analyser on scrutinizer-ci 2017-11-23 10:24:18 +01:00
.travis.yml Lock dependencies for Code Quality stage 2018-12-10 13:58:51 +01:00
build.properties New Build process 2013-09-07 12:56:49 +02:00
build.properties.dev Add support to distribute the XSD to a given directory during build process 2011-08-27 13:23:17 +02:00
build.xml New Build process 2013-09-07 12:56:49 +02:00
composer.json Update doctrine/coding-standard in 2.x branch 2018-12-10 13:58:51 +01:00
composer.lock Lock dependencies for Code Quality stage 2018-12-10 13:58:51 +01:00
CONTRIBUTING.md Removing section about jira as it has been removed. 2016-02-17 11:02:19 +01:00
doctrine-mapping.xsd Re-order attributes of relation complex types 2017-12-17 02:36:41 +01:00
LICENSE Updated year range 2015-09-29 22:52:45 +00:00
phpbench.json PHPBench base config 2017-07-23 10:16:17 +02:00
phpcs.xml.dist Update doctrine/coding-standard in 2.x branch 2018-12-10 13:58:51 +01:00
phpstan.neon Setup: Switch Apc -> Apcu and Memcache -> Memcached 2017-12-19 02:43:03 +01:00
phpunit.xml.dist Use SymfonyStyle for command output 2017-11-24 01:25:17 +01:00
README.md README: Fix PHP version 2017-12-16 22:05:22 +01:00
run-all.sh Fixed typos 2013-03-11 00:08:58 +00:00
SECURITY.md Add SECURITY.md and a chapter on security assumptions in Doctrine ORM. 2014-02-21 16:12:32 +01:00
UPGRADE.md Add UPGRADE note for EntityRepository::count() 2018-06-27 20:41:59 +02:00

Master 2.5
Build status Build status
Coverage Status Coverage Status

Doctrine 2 is an object-relational mapper (ORM) for PHP 7.1+ that provides transparent persistence for PHP objects. It sits on top of a powerful database abstraction layer (DBAL). One of its key features is the option to write database queries in a proprietary object oriented SQL dialect called Doctrine Query Language (DQL), inspired by Hibernate's HQL. This provides developers with a powerful alternative to SQL that maintains flexibility without requiring unnecessary code duplication.

More resources: