1

简而言之:播种与 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

这里有什么问题?

4

1 回答 1

3

查看第 52 行,我们发现:

$names = $this->columnize(array_keys($values[0]));

这用于构建查询的列列表部分 ( INSERT INTO (column1, column2) VALUES...)

$values在你的情况下$users,但它没有0索引。为什么? while ($i++ < 50)在进入循环体之前增加 $i ,所以第一个索引$userswill 1,而不是0Laravel SQLiteinsert实现需要的。

像这样修复它:

$i = 0;
while ($i < 49) {
    ...
    $i++;
}

为什么 MySQL 实现有效?这是此实现中相应行的样子:

$columns = $this->columnize(array_keys(reset($values)));
于 2013-10-04T07:20:43.610 回答