All Projects → envms → Fluentpdo

envms / Fluentpdo

A PHP SQL query builder using PDO

Projects that are alternatives of or similar to Fluentpdo

Loukoum
A simple SQL Query Builder
Stars: ✭ 305 (-61.05%)
Mutual labels:  builder, sql, query, postgresql
Octosql
OctoSQL is a query tool that allows you to join, analyse and transform data from multiple databases and file formats using SQL.
Stars: ✭ 2,579 (+229.37%)
Mutual labels:  sql, query, mysql, postgresql
Php Sql Query Builder
An elegant lightweight and efficient SQL Query Builder with fluid interface SQL syntax supporting bindings and complicated query generation.
Stars: ✭ 313 (-60.03%)
Mutual labels:  builder, sql, pdo, mysql
Sqliterally
Lightweight SQL query builder
Stars: ✭ 231 (-70.5%)
Mutual labels:  sql, query, mysql, postgresql
Walkable
A Clojure(script) SQL library for building APIs: Datomic® (GraphQL-ish) pull syntax, data driven configuration, dynamic filtering with relations in mind
Stars: ✭ 384 (-50.96%)
Mutual labels:  sql, query, mysql, postgresql
Qb
The database toolkit for go
Stars: ✭ 524 (-33.08%)
Mutual labels:  sql, mysql, postgresql
Go Sqlbuilder
A flexible and powerful SQL string builder library plus a zero-config ORM.
Stars: ✭ 539 (-31.16%)
Mutual labels:  sql, mysql, postgresql
Sequelize
An easy-to-use and promise-based multi SQL dialects ORM tool for Node.js
Stars: ✭ 25,422 (+3146.74%)
Mutual labels:  sql, mysql, postgresql
Vscode Sqltools
Database management for VSCode
Stars: ✭ 741 (-5.36%)
Mutual labels:  sql, mysql, postgresql
Shmig
Database migration tool written in BASH.
Stars: ✭ 408 (-47.89%)
Mutual labels:  sql, mysql, postgresql
Hibernate Springboot
Collection of best practices for Java persistence performance in Spring Boot applications
Stars: ✭ 589 (-24.78%)
Mutual labels:  sql, mysql, postgresql
Db Dumper
Dump the contents of a database
Stars: ✭ 744 (-4.98%)
Mutual labels:  sql, mysql, postgresql
Evolve
Database migration tool for .NET and .NET Core projects. Inspired by Flyway.
Stars: ✭ 477 (-39.08%)
Mutual labels:  sql, mysql, postgresql
Openrecord
Make ORMs great again!
Stars: ✭ 474 (-39.46%)
Mutual labels:  sql, mysql, postgresql
Usql
Universal command-line interface for SQL databases
Stars: ✭ 6,869 (+777.27%)
Mutual labels:  sql, mysql, postgresql
Jooq
jOOQ is the best way to write SQL in Java
Stars: ✭ 4,695 (+499.62%)
Mutual labels:  sql, mysql, postgresql
Trdsql
CLI tool that can execute SQL queries on CSV, LTSV, JSON and TBLN. Can output to various formats.
Stars: ✭ 593 (-24.27%)
Mutual labels:  sql, mysql, postgresql
Easydb
Easy-to-use PDO wrapper for PHP projects.
Stars: ✭ 624 (-20.31%)
Mutual labels:  pdo, mysql, postgresql
Beekeeper Studio
Modern and easy to use SQL client for MySQL, Postgres, SQLite, SQL Server, and more. Linux, MacOS, and Windows.
Stars: ✭ 8,053 (+928.48%)
Mutual labels:  sql, mysql, postgresql
Eralchemy
Entity Relation Diagrams generation tool
Stars: ✭ 767 (-2.04%)
Mutual labels:  sql, mysql, postgresql

FluentPDO Build Status Maintainability

FluentPDO is a PHP SQL query builder using PDO. It's a quick and light library featuring a smart join builder, which automatically creates table joins for you.

Features

  • Easy interface for creating robust queries
  • Supports any database compatible with PDO
  • Ability to build complex SELECT, INSERT, UPDATE & DELETE queries with little code
  • Type hinting for magic methods with code completion in smart IDEs

Versions

Version 2.x

The stable release of FluentPDO and actively maintained. Officially supports PHP 7.3 to PHP 8.0, but it can work with previous versions of PHP 7.

Version 1.x

The legacy release of FluentPDO. It is no longer supported and will not be maintained or updated. This version works with PHP 5.4 to 7.1.

Version 3.x - alpha

This version is a full rewrite of Fluent from the ground up. Its main advantage is significantly less memory usage and much greater performance in query building. It also places a few additional restrictions to make queries easier to read and maintain. Documentation has also been a very common request, and version 3 is being fully documented alongside development. Details and metrics will be posted once available.

Reference

Sitepoint - Getting Started with FluentPDO

Installation

Composer

The preferred way to install FluentPDO is via composer.

Add the following line in your composer.json file:

"require": {
	...
	"envms/fluentpdo": "^2.2.0"
}

update your dependencies with composer update, and you're done!

Download Zip

If you prefer not to use composer, download the latest release, create the directory Envms/FluentPDO in your library directory, and drop this repository into it. Finally, add:

require "[lib-dir]/Envms/FluentPDO/src/Query.php";

to the top of your application. Note: You will need an autoloader to use FluentPDO without changing its source code.

Getting Started

Create a new PDO instance, and pass the instance to FluentPDO:

$pdo = new PDO("mysql:dbname=fluentdb", "root");
$fluent = new \Envms\FluentPDO\Query($pdo);

Then, creating queries is quick and easy:

$query = $fluent->from('comment')
             ->where('article.published_at > ?', $date)
             ->orderBy('published_at DESC')
             ->limit(5);

which would build the query below:

SELECT comment.*
FROM comment
LEFT JOIN article ON article.id = comment.article_id
WHERE article.published_at > ?
ORDER BY article.published_at DESC
LIMIT 5

To get data from the select, all we do is loop through the returned array:

foreach ($query as $row) {
    echo "$row[title]\n";
}

Using the Smart Join Builder

Let's start with a traditional join, below:

$query = $fluent->from('article')
             ->leftJoin('user ON user.id = article.user_id')
             ->select('user.name');

That's pretty verbose, and not very smart. If your tables use proper primary and foreign key names, you can shorten the above to:

$query = $fluent->from('article')
             ->leftJoin('user')
             ->select('user.name');

That's better, but not ideal. However, it would be even easier to not write any joins:

$query = $fluent->from('article')
             ->select('user.name');

Awesome, right? FluentPDO is able to build the join for you, by you prepending the foreign table name to the requested column.

All three snippets above will create the exact same query:

SELECT article.*, user.name 
FROM article 
LEFT JOIN user ON user.id = article.user_id
Close your connection

Finally, it's always a good idea to free resources as soon as they are done with their duties:

$fluent->close();

CRUD Query Examples

SELECT
$query = $fluent->from('article')->where('id', 1);
$query = $fluent->from('user', 1); // shorter version if selecting one row by primary key
INSERT
$values = array('title' => 'article 1', 'content' => 'content 1');

$query = $fluent->insertInto('article')->values($values)->execute();
$query = $fluent->insertInto('article', $values)->execute(); // shorter version
UPDATE
$set = array('published_at' => new FluentLiteral('NOW()'));

$query = $fluent->update('article')->set($set)->where('id', 1)->execute();
$query = $fluent->update('article', $set, 1)->execute(); // shorter version if updating one row by primary key
DELETE
$query = $fluent->deleteFrom('article')->where('id', 1)->execute();
$query = $fluent->deleteFrom('article', 1)->execute(); // shorter version if deleting one row by primary key

Note: INSERT, UPDATE and DELETE queries will only run after you call ->execute()

Full documentation can be found on the FluentPDO homepage

License

Free for commercial and non-commercial use under the Apache 2.0 or GPL 2.0 licenses.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].