169 похожих чатов

Ребят всем привет, пытаюсь заполнить таблицу в которой пара значений

не может повторяться, т.е у меня есть таблица, в которой такие поля:

id area_id team_id
1 1 1
2 1 1(такого быть не может)
3 1 2 (такое быть может)
4 2 1(такое быть может)

Миграцию сделал, все работает, вручную добавлял дубликаты нельзя вставлять, т.е как выше описал.
Не получается сделать сидер:
пишу так: (возможно слишком сложно придумал)

TeamsAreaFactory.php
<?php

namespace Database\Factories;

use App\Models\TeamsArea;
use Illuminate\Database\Eloquent\Factories\Factory;

/**
* @extends \Illuminate\Database\Eloquent\Factories\Factory<\App\Models\User>
*/




class TeamsAreaFactory extends Factory
{
protected $model = TeamsArea::class;

/**
* Define the model's default state.
*
* @return array<string, mixed>
*/


public function definition(): array
{
$result = [];
$array = [];

for ($i = 0; $i < 10; $i++) {
for ($j = 0; $j < 200; $j++) {
$num1 = rand(1, 100);
$num2 = rand(1, 2000);
$combination = [$num1, $num2];

if (!in_array($combination, $array)) {
$array[] = $combination;
}
}
}

foreach ($array as $pair) {
$num1 = $pair[0];
$num2 = $pair[1];

$result[] = [
'area_id' => $num1,
'team_id' => $num2,
];
}

return $result;
}
}
TeamAreaSeeder.php
<?php
namespace Database\Seeders;
use App\Models\TeamsArea;
use Illuminate\Database\Seeder;
class TeamsAreaSeeder extends Seeder
{
public function run(): void
{
TeamsArea::factory()->times(2000)->create();
}

}

Сейчас у меня такая ошибка и не понимаю почему так, неужели скрипт требует так много памяти?
Ошибка:
Allowed memory size of 134217728 bytes exhausted (tried to allocate 20480 bytes)

at database/factories/TeamsAreaFactory.php:45
41▕ }
42▕
43▕ foreach ($array as $pair) {
44▕ $num1 = $pair[0];
➜ 45▕ $num2 = $pair[1];
46▕
47▕ $result[] = [
48▕ 'area_id' => $num1,
49▕ 'team_id' => $num2,

4 ответов

5 просмотров

𝔸ртемий, мы обнаружили что Ваше сообщение больше чем наполовину состоит из кода. Рекомендуем сохранять примеры кода на внешних источниках, например, https://paste.laravel.io

выглядит как пивот для отношений много ко многим... Зачем тебе отдельная модель, фактори и сидер? Почему бы не создать модели Area и Team и не соединить их? https://laravel.com/docs/10.x/eloquent-factories#many-to-many-relationships

Dmytro 🇺🇦
выглядит как пивот для отношений много ко многим.....

нуу, так и есть, там по сути связь многие ко многим

Похожие вопросы

Обсуждают сегодня

коллеги, добрый вечер! А никто не знает как модальная форма может себя закрыть? Ну допустим модальная форма определила, что смысла ей работать нет и хочет вернуть modalResult...
Михаил
83
Hi Everyone! To all Are you Looking for Interview Support at the Lowest Price? Look no further! Then contact us We offer Interview Support for a low cost variety of technol...
Rambabu Nallamilli
3
верно что я могу удалить эти addq и subq т.к. со стеком никакого взаимодействия нет (исключая call)?
Michael
16
А если изначально бот работал так : есть сайт онлайн школы. У каждого ученика свой кабинет. Где он авторизуется по своим данным. И уже в кабинете, на самом сайте делает оплату...
Денис 💡 Фрилансер
13
Добрый день Хочу начать обучение языку, не являюсь представителем it, буду благодарна за помощь, совсем пока не понимаю ничего) Подскажите, пожалуйста, где можно начать первы...
Sara Lala
23
средствами IBX как-то можно выполнить запрос insert ... returning?
Igor
31
А что ты вообще делаешь ?
Yesgoter
13
На работе пишем распределенное приложение, у которого сотни, если не тысячи настроек. Конфиги написаны на xml, расположены на разных хостах и должны быть согласованы друг с др...
Aleksandr Druzhinin
5
Hi there everyone Is there anyone who have not started hamster bot yet? I need only one, I'll be glad if you do this for me DM if you haven't yet
Mehrshad
53
Всем привет 🙂 Какая-то непонятная проблема у меня с видео, раньше такого не было. Загружаю видео с гугл диска именно в видео mp4 и меняю ссылку как положено вот она: https://d...
Ксюша|Верстка на Тильде|Дизайн 🦥
6
Карта сайта