Daniel Supernault a42503817b Add basic ORM implementation 6 years ago
..
Capsule a42503817b Add basic ORM implementation 5 years ago
Concerns a42503817b Add basic ORM implementation 5 years ago
Connectors a42503817b Add basic ORM implementation 5 years ago
Console a42503817b Add basic ORM implementation 5 years ago
Eloquent a42503817b Add basic ORM implementation 5 years ago
Events a42503817b Add basic ORM implementation 5 years ago
Migrations a42503817b Add basic ORM implementation 5 years ago
Query a42503817b Add basic ORM implementation 5 years ago
Schema a42503817b Add basic ORM implementation 5 years ago
ConfigurationUrlParser.php a42503817b Add basic ORM implementation 5 years ago
Connection.php a42503817b Add basic ORM implementation 5 years ago
ConnectionInterface.php a42503817b Add basic ORM implementation 5 years ago
ConnectionResolver.php a42503817b Add basic ORM implementation 5 years ago
ConnectionResolverInterface.php a42503817b Add basic ORM implementation 5 years ago
DatabaseManager.php a42503817b Add basic ORM implementation 5 years ago
DatabaseServiceProvider.php a42503817b Add basic ORM implementation 5 years ago
DetectsDeadlocks.php a42503817b Add basic ORM implementation 5 years ago
DetectsLostConnections.php a42503817b Add basic ORM implementation 5 years ago
Grammar.php a42503817b Add basic ORM implementation 5 years ago
LICENSE.md a42503817b Add basic ORM implementation 5 years ago
MigrationServiceProvider.php a42503817b Add basic ORM implementation 5 years ago
MySqlConnection.php a42503817b Add basic ORM implementation 5 years ago
PostgresConnection.php a42503817b Add basic ORM implementation 5 years ago
QueryException.php a42503817b Add basic ORM implementation 5 years ago
README.md a42503817b Add basic ORM implementation 5 years ago
SQLiteConnection.php a42503817b Add basic ORM implementation 5 years ago
Seeder.php a42503817b Add basic ORM implementation 5 years ago
SqlServerConnection.php a42503817b Add basic ORM implementation 5 years ago
composer.json a42503817b Add basic ORM implementation 5 years ago

README.md

Illuminate Database

The Illuminate Database component is a full database toolkit for PHP, providing an expressive query builder, ActiveRecord style ORM, and schema builder. It currently supports MySQL, Postgres, SQL Server, and SQLite. It also serves as the database layer of the Laravel PHP framework.

Usage Instructions

First, create a new "Capsule" manager instance. Capsule aims to make configuring the library for usage outside of the Laravel framework as easy as possible.

use Illuminate\Database\Capsule\Manager as Capsule;

$capsule = new Capsule;

$capsule->addConnection([
    'driver'    => 'mysql',
    'host'      => 'localhost',
    'database'  => 'database',
    'username'  => 'root',
    'password'  => 'password',
    'charset'   => 'utf8',
    'collation' => 'utf8_unicode_ci',
    'prefix'    => '',
]);

// Set the event dispatcher used by Eloquent models... (optional)
use Illuminate\Events\Dispatcher;
use Illuminate\Container\Container;
$capsule->setEventDispatcher(new Dispatcher(new Container));

// Make this Capsule instance available globally via static methods... (optional)
$capsule->setAsGlobal();

// Setup the Eloquent ORM... (optional; unless you've used setEventDispatcher())
$capsule->bootEloquent();

composer require "illuminate/events" required when you need to use observers with Eloquent.

Once the Capsule instance has been registered. You may use it like so:

Using The Query Builder

$users = Capsule::table('users')->where('votes', '>', 100)->get();

Other core methods may be accessed directly from the Capsule in the same manner as from the DB facade:

$results = Capsule::select('select * from users where id = ?', [1]);

Using The Schema Builder

Capsule::schema()->create('users', function ($table) {
    $table->increments('id');
    $table->string('email')->unique();
    $table->timestamps();
});

Using The Eloquent ORM

class User extends Illuminate\Database\Eloquent\Model {}

$users = User::where('votes', '>', 1)->get();

For further documentation on using the various database facilities this library provides, consult the Laravel framework documentation.