Download the PHP package ronnievisser/laravel-postgres-ext without Composer
On this page you can find all versions of the php package ronnievisser/laravel-postgres-ext. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download ronnievisser/laravel-postgres-ext
More information about ronnievisser/laravel-postgres-ext
Files in ronnievisser/laravel-postgres-ext
Package laravel-postgres-ext
Short Description Extended PostgreSQL driver for Laravel 5.x
License MIT
Informations about the package laravel-postgres-ext
Laravel 5.4 extended PostgreSQL driver
This is a clone from yurykabanov/laravel-postgres-ext and has Laravel 5.4 support.
This project was inspired by features PostgreSQL supports and Laravel does not. Unfortunately, such features are not accepted in official repository (like this one) and developers are told to use raw queries that is completely wrong solution in my opinion.
Requirements
- PHP >= 5.6 or HHVM
- PostgreSQL. Obviously it has to support particular feature you want to use. For example, to use views it has to be at least 9.1, to use upsert it has to be at least 9.5 (current stable).
Installation
- Run
composer require ronnievisser/laravel-postgres-ext
to install this package. - Change database service provider from original
Illuminate\Database\DatabaseServiceProvider::class
toRonnieVisser\Database\DatabaseServiceProvider::class
. - Models should extend
RonnieVisser\Database\Eloquent\Model
instead ofIlluminate\Database\Eloquent\Model
.
Features available
UPSERT
UPSERT (INSERT ON CONFLICT UPDATE) is supported by PostgreSQL since version 9.5 and can be performed by calling
Like original insert method, upsert can manage multiple records.
Various index types
PostgreSQL supports several index types: btree, hash, gist, spgist, gin, and brin (as for version 9.5) and other index-related features (for example, index can be created concurrently, i.e. without table locking). This package supports creation of all currently supported indexing methods.
Indexes can be created using the same syntax as original one:
but it now accepts additional parameters:
where $methodName
is one of methods listed before and $arrayOfOptions
is array with different options (like concurrency and uniqueness).
Examples:
Note, that there's two ways of making column unique: using constraint and index (more information). Laravel uses constraint to make column unique, this behavior stays the same for $table->unique()
but you can also create unique index using $table->index($col, $index, $method, [ 'unique' => true ])
.
Views
PostgreSQL supports views (since version 9.1) and materialized views (since version 9.3). These can be created using DB::statement()
but it's more convenient to use some aliases to manage them.
Views can be created using following statements:
and dropped:
So far it doesn't support some query builders since view's select statement could be (and usually is) very complicated.
Jsonb operators
Laravel claims that it does support jsonb type and jsonb operators like ?
, ?|
and ?&
. But it is impossible to use them in queries since they are treated as parameters in prepared statements. This package automatically wraps these operators in appropriate functions (Note that ?|
also used for other types -- this behavior is not supported at this moment).
Group by grouping sets, rollup, cube
Available group by expressions described in official documentation.