nattreid / orm
Extension Nextras/ORM
2.0.4
2022-03-16 09:00 UTC
Requires
- php: >= 7.4
- ext-json: *
- nette/di: ~3.0
- nextras/orm: ~4.0
Requires (Dev)
- nette/tester: ~2.4
- tracy/tracy: ~2.4
- 2.0.4
- 2.0.3
- 2.0.2
- 2.0.1
- 2.0.0
- dev-master / 1.x-dev
- 1.11.0
- 1.10.1
- 1.10.0
- 1.9.1
- 1.9.0
- 1.8.4
- 1.8.3
- 1.8.2
- 1.8.1
- 1.8.0
- 1.7.6
- 1.7.5
- 1.7.4
- 1.7.3
- 1.7.2
- 1.7.1
- 1.7.0
- 1.6.13
- 1.6.12
- 1.6.11
- 1.6.10
- 1.6.9
- 1.6.8
- 1.6.7
- 1.6.6
- 1.6.5
- 1.6.4
- 1.6.3
- 1.6.2
- 1.6.1
- 1.6.0
- 1.5.12
- 1.5.11
- 1.5.10
- 1.5.9
- 1.5.8
- 1.5.7
- 1.5.6
- 1.5.5
- 1.5.4
- 1.5.3
- 1.5.2
- 1.5.1
- 1.5.0
- 1.4.0
- 1.3.6
- 1.3.5
- 1.3.4
- 1.3.3
- 1.3.2
- 1.3.1
- 1.3.0
- 1.2.7
- 1.2.6
- 1.2.5
- 1.2.4
- 1.2.3
- 1.2.2
- 1.2.1
- 1.2.0
- 1.1.1
- 1.1.0
- 1.0.13
- 1.0.12
- 1.0.11
- 1.0.10
- 1.0.9
- 1.0.8
- 1.0.7
- 1.0.6
- 1.0.5
- 1.0.4.1
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
This package is auto-updated.
Last update: 2024-11-25 17:21:34 UTC
README
Nastavení config.neon
extensions: dbal: Nextras\Dbal\Bridges\NetteDI\DbalExtension orm: NAttreid\Orm\DI\OrmExtension dbal: dbal: driver: mysqli host: 127.0.0.1 database: test username: test password: test orm: model: App\Model\Orm useCamelCase: true autoManageDb: true # automaticka kontrola tabulek a vytvareni neexistujicich add: - Another\Orm
Model
namespace App\Model; /** * @property-read ExampleRepository $example */ class Orm extends \Nextras\Orm\Model\Model { }
Repository
class ExampleRepository extends \NAttreid\Orm\Repository { public static function getEntityClassNames() { return [Example::class]; } }
Mapper
class ExampleMapper extends \NAttreid\Orm\Mapper { protected function createTable(\NAttreid\Orm\Structure\Table $table) { $table->setDefaultDataFile(__DIR__.'/import.sql'); $table->addPrimaryKey('id') ->int() ->setAutoIncrement(); $table->addForeignKey('someId', SomeMapper::class); $table->addForeignKey('parentId', $table) ->setDefault(NULL); $table->addColumn('pa') ->varChar(20); $table->addColumn('allowed') ->boolean() ->setDefault(1) ->setKey(); $table->addUnique('someId', 'parentId'); $table->addFulltext('pa'); $relationTable = $table->createRelationTable(OtherMapper::class); $relationTable->addForeignKey('exampleId', $table); $relationTable->addForeignKey('otherId', OtherMapper::class); $relationTable->setPrimaryKey('exampleId', 'otherId'); // migrace if (!$relationTable->exists) { $table->migration[] = function (Row $row, Connection $connection) use ($relationTable) { if (isset($row->oldColumnId)) { $connection->query('INSERT INTO %table %values', $relationTable->name, [ 'exampleId' => $row->id, 'otherId' => $row->oldColumnId ]); } }; } $this->onCreateTable[] = function () { $this->insert([ [ 'id' => 1, 'someId' => 1, 'parentId' => 1, 'pa' => 'test', // ... ] ]); }; } }
Entity
/** * @property int $id {primary} * @property Some $some {m:1 Some, oneSided=true} * @property Example|NULL $parent {m:1 Example::$children} * @property OneHasMany|Example[] $children {1:m Example::$parent, orderBy=id} * @property string $pa * @property boolean $allowed {default TRUE} */ class Example extends \Nextras\Orm\Entity\Entity { }
Dokumentace na adrese https://nextras.org/orm