使用laravel模型工厂进行数据库播种可在我的本地(原始)repo / laravel项目文件中完美运行, 但是当我从github克隆遥控器时,播种会引发此错误:
第n列 找不到结果:1054“字段列表”中的未知列“ hr”(SQL:插入 到
categories
(slug
,hr
,de
,updated_at
,created_at
)v alues(CATEGORY-1,hr语言类别1的标题, 语言类别1,2018-07-09 11:19:45,2018-07-09 11:19:4 5))
迁移工作没有问题,在本地和克隆存储库上,我都使用Laravel Translatable软件包。 字段hr和de是语言环境
我尝试将其推送到远程,但是它表示一切都是最新的,我也尝试过手动将播种机和工厂从本地文件夹复制到远程/克隆文件夹,但是仍然无法正常工作。
(以下文件在原始和克隆存储库中都是相同的)
数据库播种器:
public function run()
{
$this->call([
LanguagesTableSeeder::class, //works
CategoriesTableSeeder::class, //error
MealsTableSeeder::class //error
]);
}
类别播种机:
public function run()
{
factory(App\Category::class, 5)->create();
}
类别工厂:
use Faker\Generator as Faker;
使用应用\语言;
$factory->define(App\Category::class, function (Faker $faker) {
static $counter = 1;
$locales = Language::pluck('lang');
$data = array('slug' => 'CATEGORY-'.$counter);
foreach ($locales as $locale) {
$data[$locale] = [
'title' => 'Title for category-' .$counter. ' on '. $locale . ' language'
];
}
$counter++;
return $data;
});
更新:
LanguageTableSeeder:
public function run()
{
if(!App\Language::count()) {
$defaultLanguages = array('hr','en','de');
foreach ($defaultLanguages as $language) {
App\Language::create([
'lang' => $language
]);
}
}
}
类别迁移:
public function up()
{
Schema::create('categories', function (Blueprint $table) {
$table->increments('id');
$table->string('slug');
$table->timestamps();
});
Schema::create('category_translations', function (Blueprint $table) {
$table->increments('id');
$table->integer('category_id')->unsigned();
$table->string('locale')->index();
$table->string('title');
$table->unique(['category_id','locale']);
$table->foreign('category_id')->references('id')->on('categories')->onDelete('cascade');
});
}
答案 0 :(得分:0)
好吧,所以经过几个小时或尝试一切之后,我找到了解决方案。
克隆的存储库中的供应商目录有问题。
当我从.gitignore中删除供应商时,它突然开始工作,而不是使用composer install在克隆中创建供应商,我只是将完整的原始供应商上传到了github。