Download the PHP package wtframework/orm without Composer
On this page you can find all versions of the php package wtframework/orm. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Informations about the package orm
What the Framework?! ORM
This library extends the DBAL library to provide object–relational mapping.
Installation
Documentation
Create a new model
Create a new model by extending the WTFramework\ORM\Model
class.
\
By default the table name will be a pluralized form of the class name in snake case. For example, class UserRole
will have a table name of user_roles
. If you wish to specify the table name then include a public const TABLE
.
\
By default the primary key will be the class name in snake case with a suffix of _id
. For example, class UserRole
will have a primary key of user_role_id
. If you wish to specify the primary key then include a public const PRIMARY_KEY
. This may be a string or an array (if a composite primary key).
\
By default the model will use the default database connection as defined in the DBAL configuration settings. If you wish to specify the connection name then include a public const CONNECTION
.
Insert a record
Use the create
static method to create a new record passing its data as either a stdClass object or an array. This will return a new instance of the model.
Select a record
Use the get
static method to a select a record passing its primary key as a string, an integer, or an array (if a composite primary key).
\
Use the exists
method to determine if the record was found.
\
Use the require
static method to select a record and throw a WTFramework\ORM\ModelNotFoundException
if the record was not found.
Update a record
Use the save
method to update a record. You may set the data either by manually setting the model's properties or by passing its data as either a stdClass object or an array.
Refresh a record
Use the refresh
method to undo any changes that have not been saved to the database.
\
Use the fresh
method to return a new instance of the record.
Querying the model
You can query the model using any of the methods defined by the SELECT
grammar of the SQL library. The results are then retrieved using either get
for a single model or all
for an array of models.
\ Models also provide a quick way to insert, update, delete, etc. Each of these methods return a fluent interface from the DBAL library for generating SQL statements, automatically using the defined table.
Relationships
The ORM allows for creating belongs to
, has
, has many
, has through
, and has many through
relationships.
\ By default the records will be retrieved using the models' primary keys. If you require the relationships to use different column names then you can pass them as additional parameters.
\ Use the relationship method name as a property to return the result of the relationship.
\
When relationships are retrieved this way they will be cached. Use the clearCache
method to clear the cache.
\
If you call the relationship method directly then it will return an instance of WTFramework\ORM\Query
allowing you to manipulate the results further.
\
By default relationships will be lazy loaded. This can lead to an N+1 query problem. To eager load the relationship you can call the eager
method, passing in a string or an array of relationship names to eager load.
\
You may also eager load by default by setting the public const EAGER
array.
\
When a relationship is eager loaded by default you can override this by calling the lazy
method.