简而言之:播种与 mysql 一起工作正常,而与 sqlite 中断。损坏的代码就像DB::table('user')->insert($users);
种子代码:
<?php
public function run() {
DB::table('user')->delete();
$users = array();
$birth = new DateTime('1980-03-12');
while ($i++ < 50) {
$users[$i]['email'] = "mail$i@example.com";
$users[$i]['password'] = User::password('test');
$users[$i]['enabled'] = 1;
$users[$i]['name'] = 'Name';
$users[$i]['surname'] = 'Surname';
$users[$i]['birthDate'] = $birth;
}
DB::table('user')->insert($users); //<- This line is broken when using sqlite.
}
我的默认数据库驱动程序是mysql,现在我正在尝试切换到sqlite用于测试环境。所以,在
应用程序/配置/测试/数据库.php
我有这个配置,在“连接”内(“默认”键是“sqlite”)
'sqlite' => array(
'driver' => 'sqlite',
'database' => ':memory:',
'prefix' => '',
),
现在,如果我发出
php artisan migrate --seed,这工作正常。
如果我发出
php artisan migrate --seed --env=testing,这不起作用
以上DB::table('user')->insert($users);
失败了,事实上,当我评论说播种工作正常时。命令行的错误是
ErrorException","message":"array_keys() 期望参数 1 是数组,给定 null [...] /laravel/framework/src/Illuminate/Database/Query/Grammars/SQLiteGrammar.php","line":52
这里有什么问题?