ooxif / laravel-spec-schema
Extends Laravel's Schema/Grammar/Blueprint to describe drivers' specific features
Installs: 7 518
Dependents: 0
Suggesters: 2
Security: 0
Stars: 1
Watchers: 3
Forks: 2
Open Issues: 2
Requires
- php: >=5.4.0
- illuminate/database: 5.0.*||5.1.*||5.2.*
Suggests
- ooxif/laravel-query-param: Treats binary data in a correct way with Laravel's database system (Eloquent)
This package is not auto-updated.
Last update: 2024-07-06 17:33:14 UTC
README
laravel-spec-schema
Extends Laravel's Schema/Grammar/Blueprint to describe drivers' specific features.
Install
composer require "ooxif/laravel-spec-schema:1.0.*"
then
- add
'Ooxif\LaravelSpecSchema\SpecSchemaServiceProvider',
toproviders
inconfig/app.php
. - replace
'Schema' => 'Illuminate\Support\Facades\Schema',
to'Schema' => 'Ooxif\LaravelSpecSchema\Facades\Schema',
inaliases
ofconfig/app.php
.
Examples
use Ooxif\LaravelSpecSchema\Blueprint; Schema::create('table_name', function (Blueprint $table) { // Blueprint extends Illuminate\Database\Schema\Blueprint. // add a BINARY column if the driver is MySQL, // otherwise falls back to default binary(). $table->myBinary('column_name', 8); // VARBINARY/TINYBLOB/MEDIUMBLOB/LONGBLOB also falls back to default binary(). $table->myVarBinary('column_name', 16); $table->myTinyBlob('column_name'); $table->myMediumBlob('column_name'); $table->myLongBlob('column_name'); // TINYTEXT falls back to default text(). $table->myTinyText('column_name'); // add `collate` $table->string('column_name')->collate('utf8_bin'); });
Use your own Schema Builder/Grammar/Blueprint classes
class MyMySqlBuilder extends Ooxif\LaravelSpecSchema\MySql\Builder // extends Illuminate\Database\Schema\MySqlBuilder { // your code here. } class MyMySqlGrammar extends Ooxif\LaravelSpecSchema\MySql\Grammar // extends Illuminate\Database\Schema\Grammars\MySqlGrammar { // your code here. } class MyBlueprint extends Ooxif\LaravelSpecSchema\Blueprint // extends Illuminate\Database\Schema\Blueprint { // your code here. } // setBuilderClass(string $driverName, string $className) Schema::setBuilderClass('mysql', 'MyMySqlBuilder'); // setGrammarClass(string $driverName, string $className) Schema::setGrammarClass('mysql', 'MyMySqlGrammar'); // setBlueprintClass(string $className) Schema::setBlueprintClass('MyBlueprint'); Schema::create('table_name', function ($table) { $table instanceof MyBlueprint; // true $table->getBuilder() instanceof MyMySqlBuilder; // true $table->getBuilder()->getGrammer() instanceof MyMySqlGrammar; // true });