@slip31

Как сохранить название файла в базу?

Чего то в ступор впал.
Нужно сохранить название сохраненного файла в поле базы 'photo_url'
Контроллер
public function actionCreate() {
        $model = new Doctors();
        if ($model->load(Yii::$app->request->post())) {
            $model->image = \yii\web\UploadedFile::getInstance($model, 'image');          
            if ($model->save()) {
                  $model->uploadPhoto();
                $model->photo_url = $model->fileName;               
                $this->saveSpecialities($model);               
            }
            return $this->redirect(['view', 'id' => $model->id]);
        }
        return $this->render('create', [
                    'model' => $model
        ]);
    }

 protected function saveSpecialities($model) {
        foreach ($model->specialites as $var) {
            $speciality = new DoctorsSpeciality();
            $speciality->speciality_id = $var->id;
            $speciality->doctor_id = $model->id;
            $speciality->save();
        }
    }

И в модели
public function uploadPhoto() {
        if ($this->validate()) {
            $this->fileName = $this->generateSlug() . '.' . $this->image->extension;   //Название файла генерю из названия         
            $this->image->saveAs($this->path . $this->fileName);
            Image::thumbnail($this->path . $this->fileName, 200, 200)->save($this->path_middle . $this->fileName, ['quality' => 100]);
            Image::thumbnail($this->path . $this->fileName, 100, 100)->save($this->path_small . $this->fileName, ['quality' => 100]);
            return true;
        } else {
            return false;
        }
    }

файлы сохраняются, всё нормально, но мне нужно название записать в базу $fileName
Но получаю в результате
SQLSTATE[HY000]: General error: 1364 Field 'photo_url' doesn't have a default value

Видимо не получаю я в контроллер $fileName
Чего я сделал не так?
  • Вопрос задан
  • 64 просмотра
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы