Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
P
PHP-MySQLi-Database-Class
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Kulya
PHP-MySQLi-Database-Class
Commits
a96ea382
Commit
a96ea382
authored
Jun 07, 2015
by
Alexander Butenko
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Final documentation
parent
8a9d046c
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
88 additions
and
13 deletions
+88
-13
dbObject.md
dbObject.md
+88
-13
No files found.
dbObject.md
View file @
a96ea382
...
@@ -123,28 +123,103 @@ $user->delete ();
...
@@ -123,28 +123,103 @@ $user->delete ();
```
```
###Relations
###Relations
Currently dbObject supports only hasMany and hasOne relations only. To use them declare $relations array in the model class like:
Currently dbObject supports only hasMany and hasOne relations. To use them declare $relations array in the model class.
After that you can get related object via variable names defined as keys.
HasOne example:
```
php
```
php
protected
$relations
=
Array
(
protected
$relations
=
Array
(
'person'
=>
Array
(
"hasOne"
,
"person"
,
'id'
);
'person'
=>
Array
(
"hasOne"
,
"person"
,
'id'
);
'products'
=>
Array
(
"hasMany"
,
"product"
,
'userid'
)
);
);
...
$user
=
user
::
byId
(
1
);
// sql: select * from $persontable where id = $personValue
echo
$user
->
person
->
firstName
.
" "
.
$user
->
person
->
lastName
.
" have the following products:
\n
"
;
```
```
After that you can get related object via variables and do their modification/removal/display:
In HasMany Array should be defined target object name (product in example) and a relation key (userid).
HasMany example:
```
php
```
php
protected
$relations
=
Array
(
'products'
=>
Array
(
"hasMany"
,
"product"
,
'userid'
)
);
...
$user
=
user
::
byId
(
1
);
$user
=
user
::
byId
(
1
);
// sql: select from $persontable where id = $personValue
// sql: select * from $product_table where userid = $userPrimaryKey
echo
$user
->
person
->
firstName
.
" "
.
$user
->
person
->
lastName
.
" have the following products:
\n
"
;
// sql: select from $product_table where userid = $userPrimaryKey
foreach
(
$user
->
products
as
$p
)
{
foreach
(
$user
->
products
as
$p
)
{
echo
$p
->
title
;
echo
$p
->
title
;
}
}
```
```
###Error checking
###Timestamps
TBD
Library provides a transparent way to set timestamps of an object creation and its modification:
###Validation
To enable that define $timestamps array as follows:
TBD
```
php
protected
$timestamps
=
Array
(
'createdAt'
,
'updatedAt'
);
```
Field names cant be changed.
###Validation and Error checking
Before saving and updating the row dbObject do input validation. In case validation rules are set but their criteria is not met
then save() will return an error with its description. For example:
```
php
$id
=
$user
->
save
();
if
(
!
$id
)
{
// show all validation errors
print_r
(
$user
->
errors
);
echo
$db
->
getLastQuery
();
echo
$db
->
getLastError
();
}
echo
"user were created with id"
.
$id
;
```
Validation rules must be defined in $dbFields array.
```
php
protected
$dbFields
=
Array
(
'login'
=>
Array
(
'text'
,
'required'
),
'password'
=>
Array
(
'text'
),
'createdAt'
=>
Array
(
'datetime'
),
'updatedAt'
=>
Array
(
'datetime'
),
'custom'
=>
Array
(
'/^test/'
),
);
```
First parameter is a field type. Types could be the one of following: text, bool, int, datetime or a custom regexp.
Second parameter is 'required' and its defines that following entry field be always defined.
###Array as return values
###Array as return values
TBD
dbObject can return its data as array instead of object. To do that ArrayBuilder() function should be used in the beginning of the call.
###2array and 2json
```
php
TBD
$user
=
user
::
ArrayBuilder
()
->
byId
(
1
);
echo
$user
[
'login'
];
$users
=
user
::
ArrayBuilder
()
->
orderBy
(
"id"
,
"desc"
)
->
get
();
foreach
(
$users
as
$u
)
echo
$u
[
'login'
];
```
Following call will return data only of the called instance without any relations data. Use with() function to include relation data as well.
```
php
$user
=
user
::
ArrayBuilder
()
->
with
(
"product"
)
->
byId
(
1
);
print_r
(
$user
[
'products'
]);
```
###Object serialization
Object could be easily converted to a json string or an array.
```
php
$user
=
user
::
byId
(
1
);
// echo will display json representation of an object
echo
$user
;
// userJson will contain json representation of an object
$userJson
=
$user
->
toJson
();
// userArray will contain array representation of an object
$userArray
=
$user
->
toArray
();
```
###Examples
Please look for a use examples in tests/dbObjectTests.php file and test models inside the tests/models/ directory
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment