-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathreadme.txt
222 lines (137 loc) · 5.71 KB
/
readme.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
=== NinjaDB ===
Contributors: techjewel, adreastrian
Requires at least: 4.0
Tested up to: 4.8
Stable tag: 0.8
Requires PHP: 5.3 or greater
License: GPLv3
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Donate link: https://paypal.me/zalam
Query Builder Database Wrapper for WordPress
== Description ==
A lightweight, expressive query builder for WordPress. NInjaDB use the same `$wbdp` instance and methods, It will help you to write $wpdb queries easily and expressively. At least PHP 5.3 is required.
It has some advanced features like:
- Query Like Laravel Basic Queries
- Where, orWhere methods
- Search data in all the columns or specific columns
- Easily Implement Pagination
- use insert, update or delete methods expressively.
The syntax is quite similar to Laravel's query builder.
**Simple Query:**
The query below returns the row where id = 3, null if no rows.
$row = ninjaDB('my_table')->find(3);
**Full Queries:**
$query = ninjaDB('my_table')->where('post_author', '=', 1); // for equal you can just use where('post_author, 1);
// Get result as array of objects
$query->get();
## Full Usage API
### Initiate
---
// Select a table
$query = ninjaDB()->table('post'); // post is the table name without prefix;
**OR You can pass your table name as an argument**
// Select a table
$query = ninjaDB('my_table'); // post is the table name without prefix;
## Query
### Get Easily
The query below returns the (first) row where id = 3, null if no rows.
$row = ninjaDB('my_table')->find(3);
Access your row like, `echo $row->name`. If your field name is not `id` then pass the field name as second parameter `ninjaDB('my_table')->find(3, 'author_id');`.
The query below returns the all rows as array of objects where author_id = 3, null if no rows.
$result = ninjaDB('my_table')->findAll('author_id', 3);
### Select
$query = ninjaDB('my_table')->select('*');
#### Multiple Selects
->select(array('myfield1', 'myfield2', 'amyfield3'));
Using select method multiple times `select('a')->select('b')` will also select `a` and `b`. Can be useful if you want to do conditional selects (within a PHP `if`).
#### Get All
Return an array of objects.
$query = ninjaDB('my_table')->where('author_id', 1);
$result = $query->get();
You can loop through it like:
foreach ($result as $row) {
echo $row->name;
}
#### Get First Row
$query = ninjaDB('my_table')->where('author_id', 1);
$row = $query->first();
Returns the first row, or null if there is no record. Using this method you can also make sure if a record exists. Access these like `echo $row->name`.
#### Get Rows Count, MAX, MIN, AVerage, SUM
$query = ninjaDB('my_table')->where('author_id', 1);
$count = $query->count();
$max = $query->max('views'); // Where `views` is the column name and all these will return integer / float
$min = $query->min('views');
$avg = $query->avg('views');
$avg = $query->avg('views');
$sum = $query->sum('views');
### Where
Basic syntax is `(fieldname, operator, value)`, if you give two parameters then `=` operator is assumed. So `where('name', 'jewel')` and `where('name', '=', 'jewel')` is the same.
ninjaDB('my_table')
->where('name', '=', 'jewel')
->whereNot('age', '>', 25)
->orWhere('description', 'LIKE', '%query%');
### whereIn
ninjaDB('my_table')
->whereIn( 'id', array(1,2,3) )
->get();
### Limit and Offset
->limit(30);
->offset(10);
// or you can use aliases
->take(30);
->skip(10);
### Order By
->orderBy('id', 'ASC');
### Insert
$data = array(
'name' => 'Jewel',
'description' => 'Hello, There'
);
$insertId = ninjaDB('my_table')->insert($data);
`insert()` method returns the insert id. optionally you can pass $format of your data as `->insert($data, $format);` where `$format` is an array of formats to be mapped to each of the value in $data
#### Batch Insert
$data = array(
array(
'name' => 'Jewel',
'description' => 'Hello, There'
),
array(
'name' => 'Adre',
'description' => 'Hello, I am Adre Astrian'
),
);
$insertIds = ninjaDB('my_table')->batch_insert($data);
In case of batch insert, it will return an array of insert ids.
### Update
$data = array(
'name' => 'Shahjahan Jewel',
'description' => 'Hello, There'
);
ninjaDB('my_table')->where('id', 5)->update($data);
Will update the name field to `Shahjahan Jewel` and description field to `Hello, There` where `id = 5`.
### Delete
ninjaDB('my_table')->where('id', '>', 5)->delete();
Will delete all the rows where id is greater than 5.
___
If you find any typo or extend any functionality then please edit and send a pull request.
## TODO
- [ ] join()
- [x] whereIN()
- [ ] whereNotIN()
- [ ] whereBetween
- [ ] whereNotBetween
- [ ] Having
- [ ] GroupBy
- [x] selectDistinct
*If you would like to implement any of the TODO please feel free to do and do a pull request*
And, finally, consider to contribute to this plugin [here](https://github.com/WpManageNinja/NinjaDB).
== Installation ==
In the search field type “NinjaDB” and click Search Plugins. Once you’ve found this plugin you can view details about it such as the point release, rating and description. Most importantly of course, you can install it by simply clicking “Install Now”.
== Frequently Asked Questions ==
= Where can I find documentation and user guides? =
For Expressive Documentation please [follow github repo](https://github.com/WpManageNinja/NinjaDB)
== Screenshots ==
== Changelog ==
= 0.8 - 2017-09-10 =
* Initial Release
== Upgrade Notice ==