Laravel播种:日期操作不起作用

时间:2015-06-11 08:13:00

标签: php database postgresql laravel-5 php-carbon

我有一个我想播种的数据透视表。除了PK和FK之外,该表还包含两个列:Arrival&出发(类型:时间戳)。 我使用Carbon随机填充前面的列。 这是我的代码:

$faker = Faker::create();
for( $i=0 ; $i<55500 ; $i++){
   $nowDt = Carbon::now();
   $nowDt->timezone = 'Europe/London';
   $nowDt->addMinutes($faker->numberBetween(25,55));
   $this->command->info("ARRIVAL : ". $nowDt);
   $departure = $nowDt->addMinutes($faker->numberBetween(35,45));
   $this->command->info("DEPARTURE : ". $departure);
   $region->entities()->attach($random_entity,[
            'arrival'       => $nowDt,
            'departure'     => $departure,
            'created_at'    => Carbon::now(),
            'updated_at'    => Carbon::now()
        ]);
   }

奇怪的是,输出到控制台的消息如下:

ARRIVAL : 2015-06-11 08:24:29
DEPARTURE : 2015-06-11 09:13:29

但是当我查看插入的数据时,到达和离开具有完全相同的值。

ARRIVAL : 2015-06-11 08:24:29
DEPARTURE : 2015-06-11 08:24:29

我在这里做错了什么?

1 个答案:

答案 0 :(得分:0)

这是因为你正在操纵同一个日期对象。如果需要操作日期并作为新对象返回,则在操作之前使用copy方法保留当前对象。否则它将返回对您正在操作的同一对象的引用。

更改此行

$nowDt->addMinutes($faker->numberBetween(35,45));

$nowDt->copy()->addMinutes($faker->numberBetween(35,45));