Я новичок в разработке 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 не знает о пользовательских столбцахи пытается заполнить только идентификатор автоинкремента и отметку времени.Странно, когда я запускаю этот же код на локальном сервере, все работает нормально, только когда код развертывается на тестовом сервере, я сталкиваюсь с ошибкой.
Извиняюсь за длинный вопрос, я 'мы старались включать как можно меньше, не пропуская ничего уместного.Любые предложения будут с благодарностью.