Почему Eloquent не видит все поля в моей модели при вставке в базу данных - PullRequest
1 голос
/ 11 марта 2019

Я новичок в разработке Laravel и пытаюсь создать модель Eloquent на основе базы данных SQLite.У меня есть следующий код на локальном сервере разработки, который правильно принимает запрос, строит модель и сохраняет эту модель в виде строки в таблице callback_requests.

Ниже приведен файл определения модели и файл миграции базы данных.,Я запустил миграцию, используя

php artisan migrate:reset --force
php artisan migrate 

CallbackRequest.php

namespace App\Models;

use Illuminate\Database\Eloquent\Model;

class CallbackRequest extends Model
{
    public $name;
    public $phone;
    public $email;
    public $preferredTime;
}

create_callback_requests_table (миграция) .php

use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;

class CreateCallbackRequestsTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('callback_requests', function (Blueprint $table) {
            $table->increments('id');
            $table->timestamps();
            $table->string('phone');
            $table->string('email');
            $table->string('preferredTime');
            $table->string('name');
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists('callback_requests');
    }
}

Это файл контроллера, в котором я создаю новый экземпляр моей модели, заполняю его значениями из входящего запроса и сохраняю его в БД.

MailController.php

namespace App\Http\Controllers;

use App\Models\CallbackRequest;
use App\Mail\CallbackRequestMailable;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use Illuminate\Mail\Mailable;
use Illuminate\Support\Facades\Mail;

class MailController extends Controller
{
    public function send(Request $request) 
    {
        $cbReq = new CallbackRequest();
        $cbReq->name = $request->get('name');
        $cbReq->email = $request->get('email');
        $cbReq->phone = $request->get('phone');
        $cbReq->preferredTime = $request->get('preferredTime');
        var_dump($cbReq);
        // save the entity to the database in case mail gets lost in transit
        $cbReq->save();
        // send an email to the address configured in the .env file
        $result = Mail::to(env("MAIL_CALLBACK_DELIVERY_ADDRESS"))->send(new CallbackRequestMailable($cbReq));
    }
}

Я сбросил содержимое переменной $ cbReq, ​​чтобы убедиться, что значения были добавлены правильно, и вывод, который я получаю (показан ниже), предполагает, что они имеют

object(App\Models\CallbackRequest)#222 (30) {
  ["name"]=>
  string(13) "Customer Name"
  ["phone"]=>
  string(9) "012345678"
  ["email"]=>
  string(14) "cust@email.com"
  ["preferredTime"]=>
  string(7) "morning"
  ["connection":protected]=>
  NULL
  ["table":protected]=>
  NULL
  ["primaryKey":protected]=>
  string(2) "id"
  ["keyType":protected]=>
  string(3) "int"
  ["incrementing"]=>
  bool(true)
  ["with":protected]=>
  array(0) {
  }
  ["withCount":protected]=>
  array(0) {
  }
  ["perPage":protected]=>
  int(15)
  ["exists"]=>
  bool(false)
  ["wasRecentlyCreated"]=>
  bool(false)
  ["attributes":protected]=>
  array(0) {
  }
  ["original":protected]=>
  array(0) {
  }
  ["changes":protected]=>
  array(0) {
  }
  ["casts":protected]=>
  array(0) {
  }
  ["dates":protected]=>
  array(0) {
  }
  ["dateFormat":protected]=>
  NULL
  ["appends":protected]=>
  array(0) {
  }
  ["dispatchesEvents":protected]=>
  array(0) {
  }
  ["observables":protected]=>
  array(0) {
  }
  ["relations":protected]=>
  array(0) {
  }
  ["touches":protected]=>
  array(0) {
  }
  ["timestamps"]=>
  bool(true)
  ["hidden":protected]=>
  array(0) {
  }
  ["visible":protected]=>
  array(0) {
  }
  ["fillable":protected]=>
  array(0) {
  }
  ["guarded":protected]=>
  array(1) {
    [0]=>
    string(1) "*"
  }
}

Однако, когда приложение сохраняет ошибку при сохранении, выдавая следующее сообщение:

{
    "message": "SQLSTATE[HY000]: General error: 1364 Field 'phone' doesn't have a default value (SQL: insert into     `callback_requests` (`updated_at`, `created_at`) values (2019-03-11 10:19:24, 2019-03-11 10:19:24))",
    "exception": "Illuminate\\Database\\QueryException",
    ...
}

Из сообщения об ошибке выглядит, как будто Eloquent не знает о пользовательских столбцахи пытается заполнить только идентификатор автоинкремента и отметку времени.Странно, когда я запускаю этот же код на локальном сервере, все работает нормально, только когда код развертывается на тестовом сервере, я сталкиваюсь с ошибкой.

Извиняюсь за длинный вопрос, я 'мы старались включать как можно меньше, не пропуская ничего уместного.Любые предложения будут с благодарностью.

1 Ответ

3 голосов
/ 11 марта 2019

Вам необходимо удалить свои свойства из модели.Поэтому удалите все из них:

public $name;
public $phone;
public $email;
public $preferredTime;

В противном случае, когда вы установите $model->phone = $request->phone, оно задает это свойство для вашего объекта вместо того, чтобы устанавливать ключ в массиве $attributes модели, который и сохраняется вбаза данных.

Это связано с тем, что Laravel подключает магический метод PHP __set() для установки атрибутов моделей.Вот что находится внутри базового класса Model:

/**
 * Dynamically set attributes on the model.
 *
 * @param  string  $key
 * @param  mixed  $value
 * @return void
 */
public function __set($key, $value)
{
    $this->setAttribute($key, $value);
}

Если у вас были эти свойства для IntelliSense вашей IDE (автозаполнение), вы все равно можете использовать докблок для подсказки динамических свойств:

/**
 * Class CallbackRequest
 *
 * @property-read string name
 * @property-read string phone
 * @property-read string email
 * @property-read string preferredTime
 */
class CallbackRequest extends Model {}

или используйте пакет типа Laravel IDE helper для автоматизации этого шага.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...