Using Fluent Syntax | dibi
 'sqlite3',
	'database' => 'data/sample.s3db',
));
$id = 10;
$record = array(
	'title'  => 'Super product',
	'price'  => 318,
	'active' => TRUE,
);
// SELECT ...
dibi::select('product_id')->as('id')
	->select('title')
	->from('products')
	->innerJoin('orders')->using('(product_id)')
	->innerJoin('customers USING (customer_id)')
	->orderBy('title')
	->test();
// -> SELECT [product_id] AS [id] , [title] FROM [products] INNER JOIN [orders]
//    USING (product_id) INNER JOIN customers USING (customer_id) ORDER BY [title]
// SELECT ...
echo dibi::select('title')->as('id')
	->from('products')
	->fetchSingle();
// -> Chair (as result of query: SELECT [title] AS [id] FROM [products])
// INSERT ...
dibi::insert('products', $record)
	->setFlag('IGNORE')
	->test();
// -> INSERT IGNORE INTO [products] ([title], [price], [active]) VALUES ('Super product', 318, 1)
// UPDATE ...
dibi::update('products', $record)
	->where('product_id = ?', $id)
	->test();
// -> UPDATE [products] SET [title]='Super product', [price]=318, [active]=1 WHERE product_id = 10
// DELETE ...
dibi::delete('products')
	->where('product_id = ?', $id)
	->test();
// -> DELETE FROM [products] WHERE product_id = 10
// custom commands
dibi::command()
	->update('products')
	->where('product_id = ?', $id)
	->set($record)
	->test();
// -> UPDATE [products] SET [title]='Super product', [price]=318, [active]=1 WHERE product_id = 10
dibi::command()
	->truncate('products')
	->test();
// -> TRUNCATE [products]