gpt4 book ai didi

php - 从 Laravel 工厂()获得意外响应导致段错误(核心转储)

转载 作者:行者123 更新时间:2023-11-29 16:09:28 26 4
gpt4 key购买 nike

factory()->create()->each() 内的 Laravel factory() 函数给出了非常意外的结果。该函数返回一个充满字符串和子数组的巨大数组,当在控制台内 var_dumping 它时,我必须按 ctrl+c 来阻止它渲染结果,否则它会继续运行(还没有看到数组的末尾) 。执行 php artisan DB:seed 时,我将得到以下结果:段错误(核心已转储)

数组内的内容看起来像来自 Faker 库的数据。

有人知道这可能来自哪里吗?

  • 我已将代码最小化为仅包含我想要插入数据库的模型的工厂。这当然仍然给我相同的结果。

  • 我已经从返回的对象中var_dumped了类名,返回的对象来自类“Illuminate\Database\Eloquent\FactoryBuilder”。正如预期的那样。

  • 在 SubscriptionFactory.php 文件中,我注释掉了 $factory->define() 函数中的所有内容。

代码

下面的代码给了我永无止境的数组。

factory(App\SubscriptionGroup::class, 3)
->create()
->each(function ($subscriptionGroup)
{
$test = factory(App\Subscription::class);
var_dump($test);
});

下面的代码是我的 SubscriptionFactory php 文件。

use Faker\Generator as Faker;

$factory->define(App\Subscription::class, function (Faker $faker)
{

$minAge = null;
if (rand(0, 100) > 75) {
$minAge = $faker->randomElement([12, 16, 18]);
}

$maxAge = null;
if (rand(0, 100) > 75) {
$maxAge = $faker->randomElement([21, 35, 50]);
}

$duration = 1;
if (rand(0, 100) > 25) {
$duration = $faker->randomElement([1, 6, 12, 24]);
}

$paidByMember = null;
if (rand(0, 100) > 90) {
$paidByMember = true;
} elseif (rand(0, 100) > 90) {
$paidByMember = false;
}

$tokenPeriod = \App\TokenPeriod::find(rand(1, 7));
$directDebitPeriod = \App\DirectDebitPeriod::find(rand(1, 3));

$unlimitedAccess = $faker->boolean(10);
$periodicTokens = 0;
$transferableTokenPeriod = 0;

if ( ! $unlimitedAccess) {
$periodicTokens = $faker->randomElement([1, 2, 4]);
$transferableTokenPeriod = rand(0, 4);
}

$name = implode(' ', $faker->words(rand(1, 2)));

return [
'status' => 'published',
'name' => $name,
'min_age' => $minAge,
'max_age' => $maxAge,
'membership_duration' => $duration,
'membership_duration_in' => 'months',
'available_date' => \Carbon\Carbon::now(),
'withdraw_date' => null,
'visibility_order' => 1,
'paid_by_member' => $paidByMember,
'unlimited_access' => $unlimitedAccess,
'periodic_tokens' => $periodicTokens,
'transferable_token_period' => $transferableTokenPeriod,
'check_in_access_type_id' => 1,
'token_period_id' => $tokenPeriod->id,
'direct_debit_period_id' => $directDebitPeriod->id
];
});

结果

SubscriptionGroup 工厂正在按预期运行并相应地填充数据库。但订阅工厂给出了错误的结果。请参阅下面生成的数组的一部分。

...
["de schuitjes"]=>
array(1) {
[0]=>
string(3) "van"
}
["schuitjes van"]=>
array(1) {
[0]=>
string(3) "den"
}
["den ponton-steiger"]=>
array(1) {
[0]=>
string(3) "bij"
}
["ponton-steiger bij"]=>
array(1) {
[0]=>
string(9) "Nijmegen."
}
["bij Nijmegen."]=>
array(1) {
[0]=>
string(2) "En"
}
["Nijmegen. En"]=>
array(1) {
[0]=>
string(2) "nu"
}
["nu spraken"]=>
array(1) {
[0]=>
string(2) "ze"
}
["ze over"]=>
array(2) {
[0]=>
string(3) "z'n"
[1]=>
string(2) "'t"
}
...

编辑

下面的代码似乎也会导致段错误(核心转储)错误。所以看来错误不是来自 factory(App\Subscription::class),而是来自 SubscriptionGroup 内的 subscriptions() 关系。这使得它更加奇怪,因为这只是一个简单的 hasMany 关系。

factory(App\SubscriptionGroup::class)
->create()
->each(function ($subscriptionGroup)
{
$subscriptionGroup->subscriptions();
});

SubscriptionGroup 类中的 subscriptions() 关系:

/**
* @return \Illuminate\Database\Eloquent\Relations\HasMany
*/
public function subscriptions()
{
return $this->hasMany('App\Subscription');
}

最佳答案

我找到了自己问题的答案。

对于某些模型,我创建了一个带有 $scope 属性的抽象类。该属性有一个默认值“public”。从此属性中删除默认值后,一切正常。

我已将此属性的默认值移至构造函数方法。

关于php - 从 Laravel 工厂()获得意外响应导致段错误(核心转储),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55397208/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com