Syrian DataBase
It is a simple library that depends on connecting to databases via mysql that performs data processing, as it converts ordinary data into sql code.
The library is safe and does not contain sql injection vulnerabilities. It is intended to avoid these problems, which may be somewhat difficult for beginners to avoid, and it is easy and flexible to learn.
This library was just an experiment and does not have the ability for large and medium projects because of the lack of the ability to merge tables through methods embedded in it, it is useful to add and delete data only and in the end it was just an experience for me and I learned a lot from it and today I do not advise anyone to deal with it
Index A sequential list of methods: Install Library How to install library SyDb Select Data Get data from the database Insert Data Set data from the database Update Data Update data from the database Delete Data Delete data from the database Query SQL Run SQL code Connect DataBase New connect database Close Connect DataBase Close the connect present Table Table properties Error Error Exception Some future:
You can install library with composer You can install a library using Composer which is the best way to download SyDb by adding the following line to composer.json file:
{
"require": {
"yhyasyrian/sydb": "^1.5"
}
}Or run:
composer require yhyasyrian/sydbIn the "Select" class, there are several methods of use, namely:
select_sql, select, fetch_all, fetch
Used to fetch data
Use select_sql to display an integrated sql code that accepts three parameters:
$table means the table, type String
$where means where to search, type Array value defult="[]", Syntax:
Column name => the value in it
$etcWhere It is intended to add properties to the search, Methods will be developed for it in future updates, type String value defult="".
Return Code Sql, String type.
Example:
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
$SyDb = new SyDb('localhost','root','pass','database');
$sql = $SyDb->select_sql('memers',['type'=>'admin']);
echo $sql; // SELECT * FROM `memers` WHERE `type`='admin';
// Example $_SESSION['user'] = 'Yhya'
$sql = $SyDb->select_sql('memers',['type'=>'admin','user'=>$_SESSION['user']]);
echo $sql; // SELECT * FROM `memers` WHERE `type`='admin' AND `user`='Yhya';
// Exaple $message = 'Heelo \' Yhya" I am Hak';
$sql = $SyDb->select_sql('message',['message'=>"Heelo ' Yhya\" I am Hak"]);
echo $sql; // SELECT * FROM `message` WHERE `message`='Heelo ' Yhya" I am Hak';
?>Use select to run sql code that accepts three parameters:
$table means the table, type String
$where means where to search, type Array value defult="[]", Syntax:
Column name => the value in it
$etcWhere It is intended to add properties to the search, Methods will be developed for it in future updates, type String value defult="".
Return \mysqli_result, Object type.
Example:
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
$SyDb = new SyDb('localhost','root','pass','database');
$select = $SyDb->select('memers',['type'=>'band']);
$select->num_rows; // Count rows ; int|string @link https://www.php.net/manual/en/mysqli-result.num-rows.php
// And You Can View All Data
while ($row = $SyDb->fetch($select) /*
* It is shortcut for function mysqli_fetch_assoc
*/) {
print_r($row); // For print this data
}
?>Use fetch_all to select all data that accepts three parameters:
$table means the table, type String
$where means where to search, type Array value defult="[]", Syntax:
Column name => the value in it
$etcWhere It is intended to add properties to the search, Methods will be developed for it in future updates, type String value defult="".
Return Data rows, Array type.
Example:
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
$SyDb = new SyDb('localhost','root','pass','database');
$fetch_all = $SyDb->fetch_all('memers',['type'=>'active']);
print_r($fetch_all); /* * Output is :
Array(
Array(
[id] => 1,
[type] => "active",
[name] => "Yhya"
),
Array(
[id] => 2,
[type] => "active",
[name] => "Saied"
),
)
*/
?>Use fetch to select first data that accepts three parameters:
$table means the table, type String
$where means where to search, type Array value defult="[]", Syntax:
Column name => the value in it
$etcWhere It is intended to add properties to the search, Methods will be developed for it in future updates, type String value defult="".
Return Data row, Array type.
Example:
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
$SyDb = new SyDb('localhost','root','pass','database');
$fetch = $SyDb->fetch('memers',['type'=>'active']);
print_r($fetch); /* * Output is :
Array(
[id] => 1,
[type] => "active",
[name] => "Yhya"
)
*/
?>In the "Insert" class, there are several methods of use, namely:
insert_sql, insert
Used to insert data
Use insert_sql to display an integrated sql code for add data to database that accepts two parameters:
$table means the table, type String
$data means data that you want to add into database, type Array Syntax:
Column name => the value in it
Return Code Sql, String type.
Example:
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
$SyDb = new SyDb('localhost','root','pass','database');
$sql = $SyDb->insert_sql('memers',['type'=>'admin','name'=>'Yhya']);
echo $sql; // INSERT INTO `memers` (`type`,`name`) VALUES ('admin','Yhya');
$sql = $SyDb->insert_sql('memers',['type'=>'active','name'=>'Hello I am\' Hack']);
echo $sql; // INSERT INTO `memers` (`type`,`name`) VALUES ('active','Hello I am' Hack');
?>Use insert to run an integrated sql code for add data to database that accepts two parameters:
$table means the table, type String
$data means data that you want to add into database, type Array Syntax:
Column name => the value in it
Return true, Bool type.
Example:
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
$SyDb = new SyDb('localhost','root','pass','database');
$sql = $SyDb->insert('memers',['type'=>'admin','name'=>'Yhya']); // Adding to the database is done
?>In the "Update" class, there are several methods of use, namely:
update_sql, update
Used to update data
Use update_sql to display an integrated sql code for update data to database that accepts three parameters:
$table means the table, type String
$where means where data that you want to update into database, type Array Syntax:
Column name => the value in it
$new means data that you want to update into database, type Array Syntax:
Column name => the value in it
Return Code Sql, String type.
Example:
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
$SyDb = new SyDb('localhost','root','pass','database');
$sql = $SyDb->update_sql('memers',['type'=>'admin','name'=>'Yhya'],['status'=>"online"]);
echo $sql; // UPDATE `memers` SET `status`='online' WHERE `type`='admin' AND `name`='Yhya';
$sql = $SyDb->update_sql('memers',['type'=>'active','name'=>'Hello I am\' Hack'],['status'=>"ofline"]);
echo $sql; // UPDATE `memers` SET `status`='ofline' WHERE `type`='active' AND `name`='Hello I am' Hack';
?>Use update to run an integrated sql code for update data to database that accepts three parameters:
$table means the table, type String
$where means where data that you want to update into database, type Array Syntax:
Column name => the value in it
$new means data that you want to update into database, type Array Syntax:
Column name => the value in it
Return Void type.
Example:
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
$SyDb = new SyDb('localhost','root','pass','database');
$SyDb->update('memers',['type'=>'admin','name'=>'Yhya'],['status'=>"online"]);
$SyDb->update('memers',['type'=>'active','name'=>'Hello I am\' Hack'],['status'=>"ofline"]);
?>In the "Delete" class, there are several methods of use, namely:
delete_sql, delete
Used to delte data
Use delete_sql to display sql code that accepts three parameters:
$table means the table, type String
$where means where to delete from Database, type Array Syntax:
Column name => the value in it
Return Code Sql, String type.
Example:
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
$SyDb = new SyDb('localhost','root','pass','database');
$sql = $SyDb->delete_sql('memers',['type'=>'admin']);
echo $sql; // SELECT * FROM `memers` WHERE `type`='admin';
$sql = $SyDb->delete_sql('message',['message'=>"Heelo ' Yhya\" I am Hak"]);
echo $sql; // DELETE FROM `message` WHERE `message`='Heelo ' Yhya" I am Hak';
?>Use delete to run sql code that accepts three parameters:
$table means the table, type String
$where means where to delete from Database, type Array Syntax:
Column name => the value in it
Return Void type.
Example:
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
$SyDb = new SyDb('localhost','root','pass','database');
$SyDb->delete('memers',['type'=>'admin']);
$SyDb->delete('message',['message'=>"Heelo ' Yhya\" I am Hak"]);
?>In the "Query" class, there are several methods of use, namely:
query
Used to run sql code
Use query to run sql code that accepts one parameters:
$query means sql code a type mixed
Return Mixed type
Example:
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
$SyDb = new SyDb('localhost','root','pass','database');
$SyDb->query("INSERT INTO `memers` (`type`,`name`) VALUES ('active','Hello I am' Hack');");
// Or
$SyDb->query(
$SyDb->insert_sql('memers',['type'=>'active','name'=>'Hello I am\' Hack'])
);
// Or
$SyDb->insert('memers',['type'=>'active','name'=>'Hello I am\' Hack']){Note}: Using the method can directly cause a sql injection-type hack.
To avoid the problem use the available methods, Example: select, update, etc ...
In the "Connect" class, there are several methods of use, namely:
connect
Used to connect database
Use connect a database and don't need parameters
Return true, Bool type
Example:
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
$SyDb = new SyDb('localhost','root','pass','database'); // Coonect DataBase simple
// Or
$SyDb->connect();{Note}: In PHP CLI between each connection there is an interval (Defult 15s)
In the "Close" class, there are several methods of use, namely:
close
Used to end connect database
Use end connect a database and don't need parameters
Return true, Bool type
Example:
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
$SyDb = new SyDb('localhost','root','pass','database');
$SyDb->close();
$Sydb->query('SELECT * FROM `table`'); // Error beacuse not found connect, you can connect with function connect()In the "Table" class, there are several methods of use, namely:
viewTable, exportTable, exportTables
Used to tables a database
Use view a tables in database and don't need parameters
Return all tables, Array type
Example:
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
$SyDb = new SyDb('localhost','root','pass','database');
$tables = $SyDb->viewTable();
print_r($tables); /* * Output is:
Array(
[0] => Members,
[1] => Tokens,
[2] => Logs,
[3] => Sitting,
[4] => CronsJob
)
*/
?>Use export a table in database and three parameters:
$table means the table, type String
$dir means the path for save files in it, type String
$bool for add number time UNIX for name file export, type Bool
Return true, bool type
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
$SyDb = new SyDb('localhost','root','pass','database');
$SyDb->exportTable('Members','.'); // you can show file Members.sqlUse export a tables in database and tow parameters:
$dir means the path for save files in it, type String
$bool for add number time UNIX for name file export, type Bool
Return true, bool type
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
$SyDb = new SyDb('localhost','root','pass','database');
$SyDb->exportTables('.'); // you can show file Members.sqlIn the "Error" class, In order to classify errors
Used to show errors
Example:
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
try{
$SyDb = new SyDb('localhost','root','passNoTrue','database');
} catch (\YhyaSyrian\Sql\Exception $error) {
// The error from database
echo $error->getMessage();
} catch (\Throwable $error) {
// The error from your file
echo $error->getMessage();
}Some functions help this library Example:
The function renders an array as a generic factor of all connections
Example:
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
$SyDb = new SyDb('localhost','root','pass','database');
$SyDb->addWhere(['site'=>($_SERVER['SERVER_NAME'] ?? "CLI")]);
echo $SyDb->select_sql('member',['type'=>'admin']); // SELECT * FROM `member` WHERE `type`='admin' AND `site`='CLI';
echo $SyDb->insert_sql('member',['type'=>'admin','name'=>"Yhya"]); // INSERT INTO `member` (`type`,`name`,`site`) VALUES ('admin','Yhya','CLI');
echo $SyDb->delete_sql('member',['type'=>'banded']); // DELETE FROM `member` WHERE `type`='banded' AND `site`='CLI';
echo $SyDb->update_sql('member',['status'=>'ofline','name'=>"test"],['status'=>"online"]); // UPDATE `member` SET `status`='online' WHERE `status`='ofline' AND `name`='test' AND `site`='CLI';{Advice}: It may be difficult to add the array manually if you want to change your storage format
If you want get data but start id or last time, you should function StartColumn where you can set limit and offset example:
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
$SyDb = new SyDb('localhost','root','pass','database');
echo $SyDb->select_sql('member',['type'=>'admin'],$SyDb->StartColumn('id',100,0)); // SELECT * FROM `member` WHERE `status`='admin' ORDER BY id LIMIT 0,100;If you want get data but end id or new time, you should function EtartColumn where you can set limit and offset example:
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
$SyDb = new SyDb('localhost','root','pass','database');
echo $SyDb->select_sql('member',['type'=>'admin']); // SELECT * FROM `member` WHERE `status`='admin' ORDER BY id DESC LIMIT 0,100;If you use this library with CLI, you can set time connect when every connect such as : you connect every second you don't be forced to create connections new becuse the servers are limting connections example:
<?php
require 'vendor/autoload.php';
use \YhyaSyrian\Sql\SyDb;
$SyDb = new SyDb('localhost','root','pass','database');
$SyDb->setTimeConnect(10);
$startTime = time();
$i = 0;
while ($startTime > (time() - 30)) {
$SyDb->connect();
echo $i++."-number\r";
sleep(1);
}
// Connect 3 itemEnd documentation, if you want any project, you can contact us with email: [email protected]