【问题标题】:Laravel Inserting Data to DatabaseLaravel 将数据插入数据库
【发布时间】:2020-07-05 04:19:40
【问题描述】:

我对Laravel还是新手,所以我想从某个网站学习它,并尝试使用表单将数据插入数据库mysql。

这是查看代码

<!DOCTYPE html>
<html lang="en">
 <head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
 </head>
 <body>
    <h1>Form Tambah Data</h1>
    <form action="/home/simpan" method="post">
       {{ csrf_field() }}
       Nama <input type="text" name="nama" required="required"><br/>
       Umur <input type="number" name="umur" required="required"><br/>
       Kota <input type="text" name="kota" required="required"><br/>
       <input type="submit" value="Simpan Data">
    </form>
 </body>
</html>

然后这是 web.php 代码

Route::get('/', function () {
  return view('welcome');
});

Route::get('/home', 'HomeController@index');

Route::get('/profil', function (){
   return view('profil');
});

Route::get('/home/tambah','HomeController@tambahData');

Route::post('/home/simpan','HomeController@simpan');

这是控制器代码

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;

class HomeController extends Controller
{
   //
   public function index(){
      //mengambil data dari tabel siswa
      $mahasiswa = DB::table('mahasiswa')->get();
      //mengirim data ke view mahasiswa
      return view('mahasiswa', ['mahasiswa' => $mahasiswa]);
   }

   public function tambahData(){
      return view('form_data');
   }

   public function simpan(Request $request){
       DB::table('mahasiswa')->insert([
          'nama' => $request->nama,
          'umur' => $request->umur,
          'kota' => $request->kota
       ]);
       return redirect('/home');
   }
}

数据库中的表有 4 列,“id_mahasiswa, nama, umur, kota”,我尝试只将数据插入 3 列。但是,它总是显示这个错误。

“字段 'id_mahasiswa' 没有默认值”

谁能告诉我解决办法?

【问题讨论】:

  • 字段 'id_mahasiswa' 没有默认值 你可以做三件事,或者让字段 id_mahasiswa 为 NULL,或者给一个默认值或者在插入

标签: php mysql database laravel xampp


【解决方案1】:

您的“mahasiswa”表中的数据库列“id_mahasiswa”可能具有 NOT NULL 约束且没有默认值,因此当您尝试插入没有“id_mahasiswa”值的记录时,您的查询将失败。

如果上述情况属实,您需要为该字段提供一个值或更改您正在使用的表格的设计。

【讨论】:

  • 是的,我尝试检查 null 并且它有效。非常感谢
【解决方案2】:

我查看了您的代码。例如,在您的 phpmyadmin 中,将“id_mahasiswa”列的默认值更改为 null :)

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2021-09-10
    • 2015-02-22
    • 1970-01-01
    • 1970-01-01
    • 2015-12-03
    • 2019-04-29
    • 2021-08-14
    相关资源
    最近更新 更多