Skip to content

mrrizkin/sqlbuilder

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

SQLBuilder

SQLBuilder is a PHP library for building SQL queries in a safe and efficient manner.

Installation

Use the package manager composer to install SQLBuilder.

composer require mrrizkin/sqlbuilder

Usage

use SQLBuilder\SQLBuilder;

// Select query
$sql = SQLBuilder::select("name, email")
    ->from("users")
    ->where("id", "=", 1)
    ->build();

print_r($sql);
/**
 * Output:
 * Array (
 *   [0] => SELECT "name", "email" FROM "users" WHERE "id" = ?
 *   [1] => Array (
 *     [0] => 1
 *   )
 * )
 */




// Update query
$sql = SQLBuilder::update("users")
    ->set("name", "John")
    ->where("id", "=", 1)
    ->build();

print_r($sql);
/**
 * Output:
 * Array (
 *   [0] => UPDATE "users" SET "name" = ? WHERE "id" = ?
 *   [1] => Array (
 *     [0] => John
 *     [1] => 1
 *   )
 * )
 */




// Delete query
$sql = SQLBuilder::delete("users")
    ->where("id", "=", 1)
    ->build();

print_r($sql);
/**
 * Output:
 * Array (
 *   [0] => DELETE FROM "users" WHERE "id" = ?
 *   [1] => Array (
 *     [0] => 1
 *   )
 * )
 */




// Insert query
$sql = SQLBuilder::insert("users")
    ->columns(["name", "email"])
    ->values(["john", "[email protected]"])
    ->build();

print_r($sql);
/**
 * Output:
 * Array (
 *   [0] => INSERT INTO "users" ("name", "email") VALUES (?, ?)
 *   [1] => Array (
 *     [0] => john
 *     [1] => [email protected]
 *   )
 * )
 */

Testing

Run the tests with PHPUnit:

./vendor/bin/phpunit tests

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

Please make sure to update tests as appropriate.

License

MIT

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages