2017 © Pedro Peláez
 

library query-builder

Query Builder - Making SQL composing easier

image

koine/query-builder

Query Builder - Making SQL composing easier

  • Monday, December 5, 2016
  • by mjacobus
  • Repository
  • 3 Watchers
  • 7 Stars
  • 13,440 Installations
  • PHP
  • 1 Dependents
  • 0 Suggesters
  • 7 Forks
  • 0 Open issues
  • 5 Versions
  • 15 % Grown

The README.md

Koine Query Builder

Query Builder for easing the SQL composing, (*1)

Code information:, (*2)

Build Status Coverage Status Code Climate Scrutinizer Code Quality, (*3)

Package information:, (*4)

Latest Stable Version Total Downloads Latest Unstable Version License Dependency Status, (*5)

Installing

Installing via Composer

Append the lib to your requirements key in your composer.json., (*6)

{
    // composer.json
    // [..]
    require: {
        // append this line to your requirements
        "koine/query-builder": "dev-master"
    }
}

Alternative install

Usage

SELECT

This is an example of select query., (*7)

$fields = array('u.name AS name', 'r.name AS role');

// Selecting via factory
$select = Koine\QueryBuilder::factorySelect($fields);

// Selecting via the select method
$select = Koine\QueryBuilder::factorySelect()
    ->select($fields);

// or alternatively
$select = new Koine\QueryBuilder\Statements\Select();
$select->select($fields);

// From
$select->from('users u');

// Adding joins
$select->innerJoin('roles r', 'u.id = r.user_id');

$select->toSql();

// SELECT u.name AS name, r.name AS role 
// FROM users u INNER JOIN roles r ON u.idi = r.user_id

INSERT

// Using the factory
$insert = Koine\QueryBuilder::insert();

// Or alternatively
$insert = new Koine\QueryBuilder\Statements\Insert();

$insert->into('users')->values(array(
    'name'  => 'Jon Doe',
    'email' => 'jon@doe.com'
));

$insert->toSql();

// INSERT INTO users (name, email) VALUES ('Jon Doe', 'jon@doe.com');

UPDATE

$update = Koine\QueryBuilder::update('users');

// or
$update = new Koine\QueryBuilder\Statements\Update;
$update->table('users');

// setting values and conditions

$update->set(array(
        'enabled' => 1
    ))->where('email', ':email');

$update->toSql(array(
    'email' => 'admin@email.com'
));

// UPDATE users SET enabled = 1 WHERE email = 'admin@email.com'

DELETE

TODO: Implement, (*8)

WHERE

Every time a where() method is called, the condition is added to the query., (*9)


// method signature $query->where($field, $value, $operator); // or $query->where($condition); // or $query->where(array( array($field, $value, $operator), array($condition), )); // Below some valid examples: $query->where('email', 'admin@abc.com'); // WHERE email = 'admin@abc.com' $query->where('email', 'admin@abc.com', '<>'); // WHERE email <> "admin@abc.com" $query->where('email', '%@google.com', 'LIKE'); // WHERE email LIKE "%@google.com" $query->where('age', 20); // WHERE age = 20 $query->where('code', 001); // WHERE code = 001 $query->where('code', array('value' => '001')); // WHERE code = '001' $query->where('(code = 1 OR code = 2)')); // WHERE (code = 1 OR code = 2) // multiple conditioins, one method call $query->where(array( array('email', 'admin@abc.com', '<>'), array('email', '%@google.com', 'LIKE'), array('age', 20), array('(code = 1 OR code = 2)'), array('hash', array('value' => 'SOMEFUNCTION()')), )); // WHERE condition 1 AND condition 2..

ORDER BY

$query->orderBy('name DESC');
// or
$query->orderBy(array('name DESC', 'age ASC'));

GROUP BY

$query->groupBy('a, b, c');
// or
$query->groupBy(array('a', 'b', 'b'));

LIMIT

$query->limit(2);
$query->limit(2, 1);

Using placeholders

Placeholders are a good way for building your queries when you don't know what values are going to be used (because they depend on the result of a query yet to be executed, for instance)., (*10)

$insert->into('users')->values(array(
    'name'  => ':name',
    'email' => ':email'
));

$insert->toSql(array(
    'name'  => 'Jon Doe',
    'email' => 'jon@doe.com'
));

// INSERT INTO users (name, email) VALUES ('Jon Doe', 'jon@doe.com');

Issues/Features proposals

Here is the issue tracker., (*11)

Contributing

Only TDD code will be accepted. Please follow the PSR-2 code standard., (*12)

  1. Fork it
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request

How to run the tests:

phpunit --configuration tests/phpunit.xml

To check the code standard run:

phpcs --standard=PSR2 lib
phpcs --standard=PSR2 tests

# alternatively

./bin/travis/run_phpcs.sh

License

MIT, (*13)

Authors

The Versions

05/12 2016

dev-master

9999999-dev

Query Builder - Making SQL composing easier

  Sources   Download

MIT

The Development Requires

by Marcelo Jacobus

15/09 2014

0.9.7

0.9.7.0

Query Builder - Making SQL composing easier

  Sources   Download

MIT

The Development Requires

by Marcelo Jacobus

08/09 2014

0.9.6

0.9.6.0

Query Builder - Making SQL composing easier

  Sources   Download

MIT

The Development Requires

by Marcelo Jacobus

30/07 2014

0.9.5

0.9.5.0

Query Builder - Making SQL composing easier

  Sources   Download

MIT

The Development Requires

by Marcelo Jacobus

02/07 2014