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
574943ce
Commit
574943ce
authored
Jul 08, 2015
by
Alexander Butenko
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #257 from avbdr/master
new functions
parents
6d61f870
fb611b61
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
108 additions
and
21 deletions
+108
-21
MysqliDb.php
MysqliDb.php
+31
-7
dbObject.md
dbObject.md
+12
-2
dbObject.php
dbObject.php
+64
-11
dbObjectTests.php
tests/dbObjectTests.php
+1
-1
No files found.
MysqliDb.php
View file @
574943ce
...
...
@@ -120,6 +120,12 @@ class MysqliDb
*/
public
$returnType
=
'Array'
;
/**
* Should join() results be nested by table
* @var boolean
*/
protected
$_nestJoin
=
false
;
private
$_tableName
=
''
;
/**
* Variables for query execution tracing
*
...
...
@@ -220,6 +226,8 @@ class MysqliDb
$this
->
_query
=
null
;
$this
->
_queryOptions
=
array
();
$this
->
returnType
=
'Array'
;
$this
->
_nestJoin
=
false
;
$this
->
_tableName
=
''
;
}
/**
...
...
@@ -332,7 +340,7 @@ class MysqliDb
public
function
setQueryOption
(
$options
)
{
$allowedOptions
=
Array
(
'ALL'
,
'DISTINCT'
,
'DISTINCTROW'
,
'HIGH_PRIORITY'
,
'STRAIGHT_JOIN'
,
'SQL_SMALL_RESULT'
,
'SQL_BIG_RESULT'
,
'SQL_BUFFER_RESULT'
,
'SQL_CACHE'
,
'SQL_NO_CACHE'
,
'SQL_CALC_FOUND_ROWS'
,
'LOW_PRIORITY'
,
'IGNORE'
,
'QUICK'
);
'LOW_PRIORITY'
,
'IGNORE'
,
'QUICK'
,
'MYSQLI_NESTJOIN'
);
if
(
!
is_array
(
$options
))
$options
=
Array
(
$options
);
...
...
@@ -341,6 +349,9 @@ class MysqliDb
if
(
!
in_array
(
$option
,
$allowedOptions
))
die
(
'Wrong query option: '
.
$option
);
if
(
$option
==
'MYSQLI_NESTJOIN'
)
$this
->
_nestJoin
=
true
;
else
$this
->
_queryOptions
[]
=
$option
;
}
...
...
@@ -372,8 +383,9 @@ class MysqliDb
$columns
=
'*'
;
$column
=
is_array
(
$columns
)
?
implode
(
', '
,
$columns
)
:
$columns
;
$this
->
_tableName
=
self
::
$prefix
.
$tableName
;
$this
->
_query
=
'SELECT '
.
implode
(
' '
,
$this
->
_queryOptions
)
.
' '
.
$column
.
" FROM "
.
self
::
$prefix
.
$
tableName
;
$column
.
" FROM "
.
$this
->
_
tableName
;
$stmt
=
$this
->
_buildQuery
(
$numRows
);
if
(
$this
->
isSubQuery
)
...
...
@@ -827,9 +839,15 @@ class MysqliDb
if
(
$field
->
type
==
$mysqlLongType
)
$shouldStoreResult
=
true
;
if
(
$this
->
_nestJoin
&&
$field
->
table
!=
$this
->
_tableName
)
{
$field
->
table
=
substr
(
$field
->
table
,
strlen
(
self
::
$prefix
));
$row
[
$field
->
table
][
$field
->
name
]
=
null
;
$parameters
[]
=
&
$row
[
$field
->
table
][
$field
->
name
];
}
else
{
$row
[
$field
->
name
]
=
null
;
$parameters
[]
=
&
$row
[
$field
->
name
];
}
}
// avoid out of memory bug in php 5.2 and 5.3. Mysqli allocates lot of memory for long*
// and blob* types. So to avoid out of memory issues store_result is used
...
...
@@ -844,8 +862,14 @@ class MysqliDb
while
(
$stmt
->
fetch
())
{
if
(
$this
->
returnType
==
'Object'
)
{
$x
=
new
stdClass
();
foreach
(
$row
as
$key
=>
$val
)
foreach
(
$row
as
$key
=>
$val
)
{
if
(
is_array
(
$val
))
{
$x
->
$key
=
new
stdClass
();
foreach
(
$val
as
$k
=>
$v
)
$x
->
$key
->
$k
=
$v
;
}
else
$x
->
$key
=
$val
;
}
}
else
{
$x
=
array
();
foreach
(
$row
as
$key
=>
$val
)
...
...
dbObject.md
View file @
574943ce
...
...
@@ -146,13 +146,23 @@ After that you can get related object via variable names defined as keys.
...
$user
=
user
::
byId
(
1
);
// sql: select * from
$persontable
where id = $personValue
// sql: select * from
users
where id = $personValue
echo
$user
->
person
->
firstName
.
" "
.
$user
->
person
->
lastName
.
" have the following products:
\n
"
;
// one more sql: select * from person where id=x
```
Please note, that following way of querying will execute 2 sql queries:
1.
select
*
from users where id=1;
2.
select
*
from person where id=x
In HasMany Array should be defined target object name (product in example) and a relation key (userid).
To optimize this into single select join query use with() method.
```
php
$user
=
user
::
with
(
'person'
)
->
byId
(
1
);
// sql: select * from users left join person on person.id = users.id wher id = 1;
echo
$user
->
person
->
firstName
.
" "
.
$user
->
person
->
lastName
.
" have the following products:
\n
"
;
```
##HasMany example:
In HasMany Array should be defined target object name (product in example) and a relation key (userid).
```
php
protected
$relations
=
Array
(
'products'
=>
Array
(
"hasMany"
,
"product"
,
'userid'
)
...
...
dbObject.php
View file @
574943ce
...
...
@@ -131,6 +131,9 @@ class dbObject {
* @return mixed
*/
public
function
__get
(
$name
)
{
if
(
isset
(
$this
->
data
[
$name
])
&&
$this
->
data
[
$name
]
instanceof
dbObject
)
return
$this
->
data
[
$name
];
if
(
property_exists
(
$this
,
'relations'
)
&&
isset
(
$this
->
relations
[
$name
]))
{
$relationType
=
strtolower
(
$this
->
relations
[
$name
][
0
]);
$modelName
=
$this
->
relations
[
$name
][
1
];
...
...
@@ -306,10 +309,11 @@ class dbObject {
* @return dbObject
*/
private
function
getOne
(
$fields
=
null
)
{
$results
=
$this
->
db
->
getOne
(
$this
->
dbTable
,
$fields
);
$this
->
processHasOneWith
();
$results
=
$this
->
db
->
ArrayBuilder
()
->
getOne
(
$this
->
dbTable
,
$fields
);
$this
->
processArrays
(
$results
);
$this
->
data
=
$results
;
$this
->
processWith
(
$results
);
$this
->
process
All
With
(
$results
);
if
(
$this
->
returnType
==
'Json'
)
return
json_encode
(
$results
);
if
(
$this
->
returnType
==
'Array'
)
...
...
@@ -333,17 +337,19 @@ class dbObject {
*/
private
function
get
(
$limit
=
null
,
$fields
=
null
)
{
$objects
=
Array
();
$results
=
$this
->
db
->
get
(
$this
->
dbTable
,
$limit
,
$fields
);
$this
->
processHasOneWith
();
$results
=
$this
->
db
->
ArrayBuilder
()
->
get
(
$this
->
dbTable
,
$limit
,
$fields
);
foreach
(
$results
as
&
$r
)
{
$this
->
processArrays
(
$r
);
$this
->
data
=
$r
;
$this
->
process
With
(
$r
);
$this
->
process
AllWith
(
$r
,
false
);
if
(
$this
->
returnType
==
'Object'
)
{
$item
=
new
static
(
$r
);
$item
->
isNew
=
false
;
$objects
[]
=
$item
;
}
}
$this
->
_with
=
Array
();
if
(
$this
->
returnType
==
'Object'
)
return
$objects
;
...
...
@@ -362,7 +368,10 @@ class dbObject {
* @return dbObject
*/
private
function
with
(
$objectName
)
{
$this
->
_with
[]
=
$objectName
;
if
(
!
property_exists
(
$this
,
'relations'
)
&&
!
isset
(
$this
->
relations
[
$name
]))
die
(
"No relation with name
$objectName
found"
);
$this
->
_with
[
$objectName
]
=
$this
->
relations
[
$objectName
];
return
$this
;
}
...
...
@@ -393,7 +402,7 @@ class dbObject {
* @return int
*/
private
function
count
()
{
$res
=
$this
->
db
->
getValue
(
$this
->
dbTable
,
"count(*)"
);
$res
=
$this
->
db
->
ArrayBuilder
()
->
getValue
(
$this
->
dbTable
,
"count(*)"
);
return
$res
[
'cnt'
];
}
...
...
@@ -457,7 +466,7 @@ class dbObject {
*/
public
function
toArray
()
{
$data
=
$this
->
data
;
$this
->
processWith
(
$data
);
$this
->
process
All
With
(
$data
);
foreach
(
$data
as
&
$d
)
{
if
(
$d
instanceof
dbObject
)
$d
=
$d
->
data
;
...
...
@@ -484,17 +493,61 @@ class dbObject {
}
/**
* Function queries hasMany relations if needed and also converts hasOne object names
*
* @param array $data
*/
private
function
process
With
(
&
$data
)
{
private
function
process
AllWith
(
&
$data
,
$shouldReset
=
true
)
{
if
(
count
(
$this
->
_with
)
==
0
)
return
;
foreach
(
$this
->
_with
as
$w
)
$data
[
$w
]
=
$this
->
$w
;
foreach
(
$this
->
_with
as
$name
=>
$opts
)
{
$relationType
=
strtolower
(
$opts
[
0
]);
$modelName
=
$opts
[
1
];
if
(
$relationType
==
'hasone'
)
{
$obj
=
new
$modelName
;
$table
=
$obj
->
dbTable
;
if
(
!
isset
(
$data
[
$table
]))
{
$data
[
$name
]
=
$this
->
$name
;
continue
;
}
if
(
$this
->
returnType
==
'Object'
)
{
$item
=
new
$modelName
(
$data
[
$table
]);
$item
->
returnType
=
$this
->
returnType
;
$item
->
isNew
=
false
;
$data
[
$name
]
=
$item
;
}
else
{
$data
[
$name
]
=
$data
[
$table
];
}
unset
(
$data
[
$table
]);
}
else
$data
[
$name
]
=
$this
->
$name
;
}
if
(
$shouldReset
)
$this
->
_with
=
Array
();
}
/*
* Function building hasOne joins for get/getOne method
*/
private
function
processHasOneWith
()
{
if
(
count
(
$this
->
_with
)
==
0
)
return
;
foreach
(
$this
->
_with
as
$name
=>
$opts
)
{
$relationType
=
strtolower
(
$opts
[
0
]);
$modelName
=
$opts
[
1
];
$key
=
null
;
if
(
isset
(
$opts
[
2
]))
$key
=
$opts
[
2
];
if
(
$relationType
==
'hasone'
)
{
$this
->
db
->
setQueryOption
(
"MYSQLI_NESTJOIN"
);
$this
->
join
(
$modelName
,
$key
);
}
}
}
/**
* @param array $data
*/
...
...
tests/dbObjectTests.php
View file @
574943ce
...
...
@@ -131,7 +131,7 @@ if (!is_object ($product->data['userId'])) {
$products
=
product
::
ArrayBuilder
()
->
with
(
'userId'
)
->
get
(
2
);
if
(
!
is_array
(
$products
[
0
][
'userId'
]))
{
if
(
!
is_array
(
$products
[
0
][
'userId'
])
||
!
is_array
(
$products
[
1
][
'userId'
])
)
{
echo
"Error in with processing in get"
;
exit
;
}
...
...
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