Download the PHP package modul-is/orm without Composer
On this page you can find all versions of the php package modul-is/orm. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Informations about the package orm
Licence
This repository is an overhaul of YetORM under MIT licence. Original fork kravcik/core will not be maintained for Nette3. You can find the unfinished PR for YetORM and Nette 3 here.
Abstract
This is a hybrid of a simple scalable database layer with ORM principles.
For usage and examples refer to quickstart.
Readonly
The ReadonlyProperty attribute can be used for properties that should not be written into, for example columns with auto increment.
Special types & behavior
- array - stored in database as json
- bool - stored in database as int
- \Nette\Utils\DateTime - save and load
\Nette\Utils\DateTime
Input | Entity | Nullable | Output |
---|---|---|---|
int(1) | int | ✓ || ✗ | int(1) |
int(0) | int | ✓ || ✗ | int(0) |
string("0") | int | ✓ || ✗ | Exception |
float(1.0) | float | ✓ || ✗ | float(1.0) |
float(0.0) | float | ✓ || ✗ | float(0.0) |
string("0.0") | float | ✓ || ✗ | Exception |
string("a") | string | ✓ || ✗ | string("a") |
string("") | string | ✓ || ✗ | string("") |
array(["a" => "b"]) | array | ✓ || ✗ | string("{"a":"b"}") |
array([]) | array | ✓ || ✗ | string("[]") |
string("{"a":"b"}") | array | ✓ || ✗ | Exception |
string("[]") | array | ✓ || ✗ | Exception |
bool(false) | bool | ✓ || ✗ | bool(false) |
string("false") | bool | ✓ || ✗ | Exception |
DateTime("2021-01-01 12:34:56") | DateTime | ✓ || ✗ | string("2021-01-01 12:34:56") |
string("2021-01-01 12:34:56") | DateTime | ✓ || ✗ | Exception |
int(0) | float || string || array || bool || DateTime | ✓ || ✗ | Exception |
float(0.0) | int || string || array || bool || DateTime | ✓ || ✗ | Exception |
string("") | int || float || array || bool || DateTime | ✓ || ✗ | Exception |
array([]) | int || float || string || bool || DateTime | ✓ || ✗ | Exception |
bool(false) | int || float || string || array || DateTime | ✓ || ✗ | Exception |
null | int || float || string || array || bool || DateTime | ✓ | null |
null | int || float || string || array || bool || DateTime | ✗ | Exception |
Custom types
You can also use custom types, you just have to create a class that extends \ModulIS\Datatype\Datatype
and implements both of its static functions:
1) input(string $name, $value)
- save logic (conversion into a database-compatible type)
2) output($value)
- read logic (conversion back into the original type)
Then you can use your type with a property just like all the usual types.
Just make sure the data is always wrapped in the specified class to avoid errors.
All versions of orm with dependencies
nette/utils Version ^4.0
nette/database Version ^3.0 || ^4.0
nette/bootstrap Version ^3.0