Download the PHP package runopencode/query-resources-loader-bundle without Composer
On this page you can find all versions of the php package runopencode/query-resources-loader-bundle. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download runopencode/query-resources-loader-bundle
More information about runopencode/query-resources-loader-bundle
Files in runopencode/query-resources-loader-bundle
Package query-resources-loader-bundle
Short Description Provides you with possibility to keep long queries in separate files in 'query' directory in your project.
License MIT
Informations about the package query-resources-loader-bundle
Query resources loader bundle
The purpose of query resources loader is to help you manage and organize your big, long, database queries, especially in application that deals with reporting.
Features:
- Store your queries in separate,
*.sql
files (or*sql.twig
files), in your project directory or any other directory that you want to use. - Load or execute your queries using
RunOpenCode\Bundle\QueryResourcesLoader\Contract\QueryResourcesLoaderInterface
service. - Full compatibility with Doctrine Dbal. You can move your current queries within repository classes to separate SQL
files and use query loader to execute them. Result of execution is instance of
Doctrine\DBAL\Driver\Result
. Of course, there are neat methods which you can utilize to fetch data from result set, such asgetSingleScalarResult()
,getSingleResult()
,getScalarResult()
, etc... SeeRunOpenCode\Bundle\QueryResourcesLoader\Executor\Dbal\DoctrineDbalExecutionResult
class for more details. - Automatically registers
%kernel.project_dir%/query
directory as query resources directory, as well as allquery
directories withinResources
directories of your bundles. - Integrated with Twig, so you can use Twig syntax in your queries. You can use this feature to build complex
queries, depending on your application logic. Beside control flow statements, you can use all Twig filters, functions,
tests and blocks as well. With
{% include %}
,{% embed %}
,{% use %}
and{% extends %}
statements, you can reuse your queries and build complex queries from smaller ones. - Transactions. You can execute your queries within transaction. Supports
transactional()
API from Doctrine Dbal. You can control transaction isolation level for current statements within transaction. - Distributed transactions. You can execute multiple queries within same transaction against different databases. If any of statements fail, transaction will be rolled back for all databases.
- Caching. You can cache your query results, so they are not loaded from database on each execution.
- Middlewares. You can use middlewares to manipulate query before execution, or to manipulate result after execution. You can switch to other database if query fails, you can add monitoring, logging, load balancing on several databases, etc...
Read the documentation here.
Quick example
Typical reporting repository that has a query string within repository can be implemented like as in example below:
This is terrible, as it mixes SQL with PHP code, and it is hard to maintain!
With this bundle, you can store your queries in %kernel.project_dir%/query
directory as standard .sql
file (or
.sql.twig
if you use Twig, or any other extension that your query language uses) and load it and execute it using
RunOpenCode\Bundle\QueryResourcesLoader\Contract\QueryResourcesLoaderInterface
service, thus, decreasing amount of
code in your repository classes:
Building complex queries
Sometimes, you will need a possibility to build up your queries depending on your application logic. For that purpose, query loader uses Twig and all your query resources are pre-parsed with Twig, allowing you to dynamically build your queries, per example:
For other details about this bundle, as well as for tips on how to use it, read the documentation here.
TODO
- Add profiling for middlewares and query execution.
All versions of query-resources-loader-bundle with dependencies
ext-ctype Version *
doctrine/dbal Version ^2.0|^3.0|^4.0
doctrine/orm Version ^2.0|^3.0|^4.0
doctrine/persistence Version ^1.3|^2.0|^3.0|^4.0
symfony/config Version ^4.0|^5.0|^6.0|^7.0
symfony/dependency-injection Version ^4.0|^5.0|^6.0|^7.0
symfony/finder Version ^4.0|^5.0|^6.0|^7.0
symfony/http-kernel Version ^4.0|^5.0|^6.0|^7.0
symfony/twig-bundle Version ^4.0|^5.0|^6.0|^7.0
twig/twig Version ^2.0|^3.0
symfony/doctrine-bridge Version ^4.0|^5.0|^6.0|^7.0
doctrine/doctrine-bundle Version ^1.0|^2.0
symfony/cache Version ^4.0|^5.0|^6.0|^7.0
symfony/cache-contracts Version ^1.0|^2.0|^3.0