diff --git a/README.md b/README.md
index 22f0bb1..ddcf116 100644
--- a/README.md
+++ b/README.md
@@ -1,95 +1,82 @@
# SuperSQL
-SuperSQL is an easy-to-use powerful SQL query builder for SQLite and MySQL.
+SuperSQL is an easy-to-use, yet powerful SQL query builder for SQLite and MySQL.
## Requirements
-* PHP 5.6+
+* PHP 7+
* PDO SQLite / MySQL driver
## Setup
-* Download the ssql.php file ([https://raw.githubusercontent.com/ratajs/SuperSQL/2.2/ssql.php](https://raw.githubusercontent.com/ratajs/SuperSQL/2.2/ssql.php))
+* Download the ssql.php file ([https://raw.githubusercontent.com/ratajs/SuperSQL/2.3/ssql.php](https://raw.githubusercontent.com/ratajs/SuperSQL/2.3/ssql.php))
* Include the file with `include` / `require`
## Examples
-Let’s have a table “users” with 5 columns: `uid`, `username`, `password`, `sign_up_time` and `nickname`
+Let’s have a table ‘users’ with 5 columns: `uid`, `username`, `password`, `sign_up_time` and `nickname`
```php
q($q[, $a]), FETCH_ALL returns an array of rows, FETCH_OBJECT and FETCH_ARRAY return one row per call
- $ssql->q("SELECT * FROM users")->fetch(SQ::FETCH_ALL);
-
- //You can use wildcards for escaping
- $ssql->q("SELECT * FROM users WHERE `username`=%0 OR `nickname`=%1", [$name, $nick])->fetch();
-
- //You can set the object‐wide $debug property to print all queries before being executed
- $ssql->debug = true;
-
- //You can use queries as methods
- $ssql->getUser = "SELECT * FROM users WHERE `username`=%0 OR `nickname`=%1";
- $user = $ssql->getUser($name, $nick)->fetch();
-
- //For simple requests use $ssql->read($table[, $cond][, $flags])
- //Read function uses FETCH_SMART as default (FETCH_OBJECT for one row, FETCH_ALL for more), so you need to use the FETCH_ALL flag to return an array even when there is only one result
- $users = $ssql->read("users", SQ::FETCH_ALL);
- $user = $ssql->read("users", ['uid' => $id]);
-
- //You can use the DEBUG flag to print this query before execution
- $user = $ssql->read("users", ['uid' => $id], SQ::DEBUG);
-
- //You can use more conditions
- $user = $ssql->read("users", ['username' => $name, 'password' => $pass]);
-
- //You can use the COND_OR flag for OR operator instead of AND
- $user = $ssql->read("users", ['username' => $name, 'nickname' => $nick], SQ::FETCH_ALL | SQ::COND_OR)[0];
-
- //You can use custom conditions
- $users = $ssql->read("users", "`sign_up_time` > " . bcsub(time(), 3600));
-
- //You can use more of them
- $users = $ssql->read("users", ["`sign_up_time` > " . bcsub(time(), 3600), "`nickname` IS NOT NULL"], SQ::FETCH_ALL);
-
- //For more complicated requests use $ssql->select($table[, $order[, $cols[, $limit[, $flags]]]]), you can use array keys for aliases
- $users = $ssql->select("users", "sign_up_time", ['id' => "uid", 'name' => "username", "sign_up_time", "nickname"], NULL, SQ::ORDER_DESC)->fetch(SQ::FETCH_ALL);
-
- //Or $ssql->selectWhere($table, $cond[, $order[, $cols[, $limit[, $flags]]]])
- $user = $ssql->selectWhere("users", ['uid' => $id], "name", ['id' => "uid", 'name' => "username", "sign_up_time", 'nick' => "nickname"])->fetch();
-
- //To quickly display tables use ->dump()
- $ssql->select("users")->dump();
-
- //Insert with $ssql->insert($table, $values[, $flags])
- $ssql->insert("users", [$id, $name, $pass, time(), NULL]);
-
- //You can use array keys as col names
- $ssql->insert("users", ['username' => $name, 'password' => $pass, 'sign_up_time' => time()]);
-
- //You can use INSERT_RETURN_ID flag for returning the first auto increment col value (depends on the database type)
- $id = $ssql->insert("users", ['username' => $name, 'password' => $pass, 'sign_up_time' => time()], SQ::INSERT_RETURN_ID);
-
- //Use $ssql->update($table, $cond, $values[, $flags]) to update rows
- $ssql->update("users", ['id' => $id], ['nickname' => $nick]);
-
- //You can delete rows with $ssql->delete($table, $cond[, $flags])
- $ssql->delete("users", ['id' => $id]);
-
- //You can use $ssql->put($table, $data[, $cond][, $flags]) for inserting, updating and deleting as well
- //Insert
- $ssql->put("users", [$id, $name, $pass, time(), NULL]);
- $ssql->put("users", ['username' => $name, 'password' => $pass, 'sign_up_time' => time()], SQ::INSERT_RETURN_ID);
- //Update
- $ssql->put("users", ['nickname' => $nick], ['id' => $id]);
- //Delete
- $ssql->put("users", NULL, ['id' => $id]);
-
- //Use $ssql->truncate($table[, $flags]) to delete all rows in a table
- $ssql->truncate("users");
+ include "ssql.php";
+
+ //Connect to MySQL with new SSQL($host[, $user[, $password[, $database]]])
+ $ssql = new SSQL("localhost", "root", "root", "db");
+
+ //Connect to SQLite with just the first argument
+ $ssql = new SSQL("db.sqlite3");
+
+ //Use $ssql->q($q[, $a]) to execute a raw SQL query
+ $ssql->q("SELECT * FROM `users`");
+
+ //You can use wildcards for escaping
+ $ssql->q("SELECT * FROM `users` WHERE `username`=%0 OR `nickname`=%1", [$name, $nick]);
+
+ //You can use queries as methods
+ $ssql->getUser = "SELECT * FROM `users` WHERE `username` = '%0' OR `nickname` = '%1'";
+ $user = $ssql->getUser($name, $nick);
+
+ //Use $ssql->read($table[, $cond][, $flags]) for simple reading
+ $users = $ssql->read("users"); // Access the username of a specific user with $users[$index]->username
+ $users = $users->data(); // If you need a raw array, for example for json_encode($users)
+ $user = $ssql->read("users", ['uid' => $id]); // You can access the username with $user->username if only one result is returned
+
+ //You can use the DEBUG flag to print this query before execution
+ $user = $ssql->read("users", ['uid' => $id], SQ::DEBUG);
+
+ //Or you can set the object‐wide $debug property to print all queries
+ $ssql->debug = true;
+
+ //You can use more conditions
+ $user = $ssql->read("users", ['username' => $name, 'password' => $pass]);
+
+ //You can use the COND_OR flag to use the OR operator instead of AND
+ $user = $ssql->read("users", ['username' => $name, 'nickname' => $nick], SQ::COND_OR)[0];
+
+ //You can use custom conditions
+ $users = $ssql->read("users", "`sign_up_time` > " . bcsub(time(), 3600));
+
+ //You can use more of them
+ $users = $ssql->read("users", ["`sign_up_time` > " . bcsub(time(), 3600), "`nickname` IS NOT NULL"]);
+
+ //Use $ssql->get($table[, $options][, $flags]) for more complex data retrieval
+ $users = $ssql->get("users", ['order' => "sign_up_time", 'cols' => ['id' => "uid", 'name' => "username", "sign_up_time", "nickname"], 'limit' => 10], SQ::ORDER_DESC);
+ $user = $ssql->get("users", ['cond' => ['uid' => $id], 'order' => "name", 'cols' => ['id' => "uid", 'name' => "username", "sign_up_time", 'nick' => "nickname"]]);
+
+ //You can print the result of a ->read() or ->get() call as an HTML table
+ print $ssql->read("users");
+
+ //Insert with $ssql->put($table, $values[, $flags])
+ $ssql->put("users", [$id, $name, $pass, time(), NULL]);
+
+ //You can use array keys as col names
+ $ssql->put("users", ['username' => $name, 'password' => $pass, 'sign_up_time' => time()]);
+
+ //You can use INSERT_RETURN_ID flag for returning the first auto increment col value (depends on the database type)
+ $id = $ssql->put("users", ['username' => $name, 'password' => $pass, 'sign_up_time' => time()], SQ::INSERT_RETURN_ID);
+
+ //Use $ssql->put($table, $values, $cond[, $flags]) to update rows
+ $ssql->put("users", ['nickname' => $nick], ['uid' => $id]);
+
+ //You can delete rows by supplying NULL to the $values argument
+ $ssql->put("users", NULL, ['uid' => $id]);
+ $ssql->put("users", NULL); //Delete all users
?>
```
@@ -104,10 +91,7 @@ Here is list of all SuperSQL flags:
* INSERT_RETURN_ID
* COND_AND
* COND_OR
-* FETCH_OBJECT
-* FETCH_ARRAY
-* FETCH_ALL
-* FETCH_SMART
+* CASE_INSENSITIVE
* NO_ERROR
* DEBUG
@@ -115,70 +99,76 @@ Here is list of all SuperSQL flags:
```php
changeDb("newDB");
-
-
- //Join
-
-
- //Use $ssql->selectJoin($table, $join, $on[, $order[, $cols[, $limit[, $flags]]]]) to execute a JOIN command
- $result = $ssql->selectJoin("users", "messages", ['from_user' => 'uid'], "time", "*", 5, SQ::ORDER_DESC)->fetch(SQ::FETCH_ALL);
- //Use JOIN_LEFT, JOIN_RIGHT and JOIN_FULL flags to other types of JOIN
-
- //To combine JOIN and WHERE use $ssql->selectJoinWhere($table, $join, $on, $cond[, $order[, $cols[, $limit[, $flags]]]])
- $result = $ssql->selectJoinWhere("users", "messages", ['from_user' => 'uid'], ['from_user' => $uid])->fetch(SQ::FETCH_ALL);
-
-
-
- //Table creation and deletion
-
-
- //For basic table creation use $ssql->createTable($table, $params[, $primary[, $flags]])
- $ssql->createTable("myTable", [
- 'number' => [ // Column name
- 'type' => "int", // Column type
- 'NULL' => false // NULL
- ],
- 'text' => [
- 'type' => "varchar",
- 'length' => 64, // Max length
- 'NULL' => true
- ]
- ], "number");
-
- //Use $ssql->deleteTable($table[, $flags]) to delete a table
- $ssql->deleteTable("myTable");
-
- //To see a list of all tables in your database use $ssql->tableList([$flags])
- print_r($ssql->tableList());
-
-
- //Advanced conditions
-
-
- //You can use more advanced conditions with $ssql->cond(), this will select users that have the same username and nickname signed up in the last hour
- $ssql->read("users", $ssql->cond()->eq("username", "nickname")->gte("sign_up_time", time() - 3600));
-
- //Use arrays to differentiate string values from column names and to specify more alternatives, the COND_OR flag is also supported
- //This will select users that have username either "ratajs" or "admin" or that have nickname "RatajS"
- $ssql->read("users", $ssql->cond()->eq("username", ["ratajs", "admin"])->eq("nickname", ["RatajS"], SQ::COND_OR));
-
- //->not() negates the condition, this will select users with usernames other than admin
- $ssql->read("users", $ssql->cond()->eq("username", ["admin"])->not());
-
- //You can also pass another condition to it, this will select users that don’t have any nickname with username other than "admin" or "root".
- $ssql->read("users", $ssql->cond()->eq("nickname", [""])->not($ssql->cond()->eq("username", ["admin", "root"])));
-
- //Supported conditions: ->eq(), ->lt(), ->gt(), ->lte(), ->gte(), ->like(), ->between(), ->begins(), ->ends(), ->contains() and ->in()
+ //You can extend the SSQL class
+ class MySSQL extends SSQL {
+ protected $host = "localhost";
+ protected $user = "root";
+ protected $password = "root";
+ protected $db = "db"; //Optional
+ };
+ //And then create an instance
+ $ssql = new MySSQL();
+ //If $db is not set, you can set it afterwards
+ $ssql->changeDb("newDB");
+
+
+ //Join
+
+
+ $result = $ssql->get("users", ['join' => "messages", 'on' => ['from_user' => 'uid'], 'order' => "time", 'limit' => 5], SQ::ORDER_DESC);
+ //Use JOIN_LEFT, JOIN_RIGHT and JOIN_FULL flags for other types of JOIN
+
+ $result = $ssql->get("users", ['join' => "messages", 'on' => ['from_user' => 'uid'], 'cond' => ['from_user' => $uid]]);
+
+
+
+ //Table creation and deletion
+
+
+ //For basic table creation use $ssql->createTable($table, $params[, $primary[, $flags]])
+ $ssql->createTable("myTable", [
+ 'number' => [
+ 'type' => "int",
+ 'NULL' => false
+ ],
+ 'text' => [
+ 'type' => "varchar",
+ 'size' => 64,
+ 'NULL' => true
+ ]
+ ], "number"); // Primary key
+
+ //Use $ssql->deleteTable($table[, $flags]) to delete a table
+ $ssql->deleteTable("myTable");
+
+ //To see a list of all tables in your database use $ssql->tableList([$flags])
+ print_r($ssql->tableList());
+
+
+ //Advanced conditions
+
+
+ //You can use more advanced conditions with $ssql->cond(), this will select users that have the same username and nickname signed up in the last hour
+ $ssql->read("users", $ssql->cond()->eq("username", "nickname")->gte("sign_up_time", time() - 3600));
+
+ //Use arrays to differentiate string values from column names and to specify more alternatives, the COND_OR flag is also supported
+ //This will select users that have username either "ratajs" or "admin" or that have nickname "RatajS"
+ $ssql->read("users", $ssql->cond()->eq("username", ["ratajs", "admin"])->eq("nickname", ["RatajS"], SQ::COND_OR));
+
+ //->not() negates the condition, this will select users with usernames other than admin
+ $ssql->read("users", $ssql->cond()->eq("username", ["admin"])->not());
+
+ //You can also pass another condition to it, this will select users that don’t have any nickname with username other than "admin" or "root".
+ $ssql->read("users", $ssql->cond()->eq("nickname", [""])->not($ssql->cond()->eq("username", ["admin", "root"])));
+
+ //Supported conditions: ->eq(), ->lt(), ->gt(), ->lte(), ->gte(), ->like(), ->between(), ->begins(), ->ends(), ->contains() and ->in()
+
+ //Transactions
+
+ $ssql->beginTransaction();
+
+ //...
+
+ $ssql->endTransaction(); //Or $ssql->rollBackTransaction()
?>
```
diff --git a/ssql.php b/ssql.php
index be9b6a8..fcb3b5b 100644
--- a/ssql.php
+++ b/ssql.php
@@ -49,14 +49,9 @@ abstract class SQ {
const INSERT_RETURN_ID = 64;
const COND_AND = 128;
const COND_OR = 256;
- const FETCH_OBJECT = 512;
- const FETCH_ARRAY = 1024;
- const FETCH_ALL = 2048;
- const FETCH_SMART = 4096;
- const FETCH_HTML = 8192;
- const CASE_INSENSITIVE = 16384;
- const NO_ERROR = 32768;
- const DEBUG = 65536;
+ const CASE_INSENSITIVE = 512;
+ const NO_ERROR = 1024;
+ const DEBUG = 2048;
static function open(string $host = "", string $user = "", string $password = "", string $db = "", &$object = "return") {
if($object=="return")
@@ -606,30 +601,6 @@ public function get(string $table, $options = [], int $flags = 0) {
$jointype = boolval($flags & self::JOIN_FULL) ? self::JOIN_FULL : (boolval($flags & self::JOIN_RIGHT) ? self::JOIN_RIGHT : (boolval($flags & self::JOIN_LEFT) ? self::JOIN_LEFT : self::JOIN_INNER));
else
$jointype = $options['join_type'];
- if($flags & self::FETCH_OBJECT)
- $flags-= self::FETCH_OBJECT;
- if($flags & self::FETCH_ARRAY)
- $flags-= self::FETCH_ARRAY;
- if($flags & self::FETCH_ALL)
- $flags-= self::FETCH_ALL;
- if($flags & self::FETCH_SMART)
- $flags-= self::FETCH_SMART;
- if($flags & self::COND_AND)
- $flags-= self::COND_AND;
- if($flags & self::COND_OR)
- $flags-= self::COND_OR;
- if($flags & self::ORDER_ASC)
- $flags-= self::ORDER_ASC;
- if($flags & self::ORDER_DESC)
- $flags-= self::ORDER_DESC;
- if($flags & self::JOIN_INNER)
- $flags-= self::JOIN_INNER;
- if($flags & self::JOIN_LEFT)
- $flags-= self::JOIN_LEFT;
- if($flags & self::JOIN_RIGHT)
- $flags-= self::JOIN_RIGHT;
- if($flags & self::JOIN_FULL)
- $flags-= self::JOIN_FULL;
$cond = $options['cond'] ?? false;
$join = $options['join'] ?? false;
$on = $options['on'] ?? false;
diff --git a/tests.php b/tests.php
index a195651..6b1171d 100644
--- a/tests.php
+++ b/tests.php
@@ -518,7 +518,7 @@
assert($r[0]->num==16);
assert($r[1]->num==48);
- $ssql->q("UPDATE `table3` SET `table3_num` = \"%1\" WHERE `table3_id` = \"%0\"", "3", "42");
+ $ssql->q("UPDATE `table3` SET `table3_num` = '%1' WHERE `table3_id` = '%0'", "3", "42");
$r = $ssql->read("table3");
assert(count($r)==4);
assert($r[0]->table3_id==1);
@@ -537,7 +537,7 @@
assert(count($r)==1);
assert($r[0]->num==16);
- $ssql->inc = "UPDATE `table3` SET `table3_num` = `table3_num` + 1 WHERE `table3_id` = %0";
+ $ssql->inc = "UPDATE `table3` SET `table3_num` = `table3_num` + 1 WHERE `table3_id` = '%0'";
$ssql->inc(4);
$r = $ssql->read("table3");
assert(count($r)==4);