This package makes the Atlas ORM and command-line tooling available as a bundle for Symfony 4 projects.
(Atlas is a data mapper for your persistence layer, not your domain layer.)
-
In your Symfony 4 project, enable contributor recipes:
composer config extra.symfony.allow-contrib true
-
Require the
atlas/symfony
package; this will activate a Symfony Flex recipe as part of the installation:composer require atlas/symfony ~1.0
-
Edit these new
.env
variables to define your database connection:ATLAS_PDO_DSN=mysql:host=myhost;dbname=mydatabase ATLAS_PDO_USERNAME=myusername ATLAS_PDO_PASSWORD=mypassword
Note:
If you are using PHPStorm, you may wish to copy the IDE meta file to your project to get full autocompletion on Atlas classes:
cp ./vendor/atlas/orm/resources/phpstorm.meta.php ./.phpstorm.meta.php
In the atlas.yaml
config file, these settings are notable:
-
atlas.orm.atlas.log_queries
: set this totrue
to enable the web profiler data collector for query logging. -
atlas.orm.atlas.transaction_class
: set this to one of the Atlas transaction strategy classes, such asAtlas\\Orm\\Transaction\\AutoTransact
. For more information, see the transactions documentation. -
The
options
section under any connection configuration can be used to set PDO attributes through the PDO constructor. For example:dsn: '%env(resolve:ATLAS_PDO_DSN)%' username: '%env(resolve:ATLAS_PDO_USERNAME)%' password: '%env(resolve:ATLAS_PDO_PASSWORD)%' options: !php/const PDO::EMULATE_PREPARES: false !php/const PDO::ATTR_CASE: !php/const PDO::CASE_NATURAL
Use the command-line tooling to create the skeleton files for all your database tables:
mkdir src/DataSource
php bin/console atlas:skeleton
The config/packages/atlas.yaml
file specifies App\DataSource\
as the
namespace, and src/DataSource/
as the directory. To change them, modify the
atlas.cli.config.input
values for directory
and namespace
as you see fit.
The database table names will be converted to singular for their relevant
type names in PHP. If you want a different type names for certain tables,
modify the atlas.cli.transform
values in the atlas.yaml
file to map a
from table name to a type name.
As you make changes to the database, re-run the skeleton generator, and the relevant table files will be regenerated.
For more information, see http://atlasphp.io/cassini/skeleton/.
Now that there are mappers for all the database tables, you can use the Symfony dependency injection system to autowire Atlas into your classes for you.
namespace App;
use Atlas\Orm\Atlas;
use App\DataSource\Thread\Thread
use App\DataSource\Thread\ThreadRecord;
class ApplicationService
{
public function __construct(Atlas $atlas)
{
$this->atlas = $atlas;
}
public function fetchThreadById($thread_id) : ThreadRecord
{
return $this->atlas->fetchRecord(Thread::class, $thread_id);
}
}
Full documentation for using Atlas is at http://atlasphp.io/cassini/orm/:
-
Working with Records and RecordSets
-
Other topics such as custom mapper methods, single table inheritance, many-to-many relationships, and automated validation
Enjoy!