laykou/schema 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

laykou/schema

Composer 安装命令:

composer require laykou/schema

包简介

Schema saving and loading from file for CakePHP 3.0

README 文档

README

Save the schema into one file and then restore the database from the schema file. The schema is automatically saved when executing cake migrations migrate.

Supported datasources

  • Postgres
  • MySQL
  • SQL Server
  • SQLite not yet

Installation

You can install this plugin into your CakePHP application using composer.

The recommended way to install composer packages is:

composer require-dev laykou/schema

Update your `config/bootstrap.php``:

Plugin::load('Schema', ['bootstrap' => true]);

Usage

The plugin saves the schema of the default connection to the config/schema.php file. The structure is similiar to the fixtures fields.

cake schema save

To load the schema back execute

cake schema load

All existing tables in the database are dropped before loading. You will be asked

Loading the schema from the file Database is not empty. 37 tables will be deleted.
Do you want to continue? (y/n)

To disable the question (and answer with yes) run

cake schema load --no-interaction

Seed

The Schema plugin allows you to seed data from the config/seed.php file. The seed.php file should return array of tables and rows:

<?php
// You can work with custom libraries here or use the Cake's ORM
return [
    'articles' => [
        [
            'id' => 1,
            'category_id' => 1,
            'label' => 'CakePHP'
        ], [
            'id' => 2,
            'label' => 'Schema plugin'
        ]
    ],
    'categories' => [
        [
            'id' => 2,
            'label' => 'Frameworks'
        ]
    ]
];

Other examples

cake schema save --connection test
cake schema save --path config/schema/schema.lock
cake schema load --connection test --path config/schema/schema.lock --no-interaction

# To only drop all tables in database
cake schema drop
cake schema drop --connection test

# Truncate tables before inserting. Otherwise duplicate ID exception is thrown.
cake schema seed --truncate
cake schema seed --seed custom/path/to/seed.php
cake schema seed --connection test --truncate

To seed the data into database run following command:

cake schema seed

TODO

  • Auto-creation of the schema.php file after cake migrations migrate
  • Data seeding
  • Tests
  • More options and configuration
  • Refactoring and cleaning the code

Known issues

  • SQLite is not fully supported

统计信息

  • 总下载量: 1.54k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 3
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 3
  • Watchers: 2
  • Forks: 2
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2015-03-08