【问题标题】:error in Laravel8: SQLSTATE[42S02]: Base table or view not found: 1146 TableLaravel8 中的错误:SQLSTATE [42S02]:未找到基表或视图:1146 表
【发布时间】:2021-02-05 12:49:32
【问题描述】:

我已经使用 Laravel 8 开始了一个新项目。 我使用入门套件 Laravel Breeze。 但我无法自定义字段。 我已经更改了迁移和注册控制器和用户模型中的字段。

这是我的代码:


迁移文件。

<?php

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

class TblUsers extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('tbl_users', function (Blueprint $table) {
            $table->id();
            $table->string('fullname');
            $table->string('username');
            $table->string('email')->unique();
            $table->timestamp('email_verified_at')->nullable();
            $table->string('phone');
            $table->string('organization_type');
            $table->string('community_dev_auth_id');
            $table->string('file_names');
            $table->string('password');
            $table->rememberToken();
            $table->timestamps();
        });
    }

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

注册控制器文件。

<?php

namespace App\Http\Controllers\Auth;

use App\Http\Controllers\Controller;
use App\Models\User;
use App\Providers\RouteServiceProvider;
use Illuminate\Auth\Events\Registered;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Hash;

class RegisteredUserController extends Controller
{
    /**
     * Display the registration view.
     *
     * @return \Illuminate\View\View
     */
    public function create()
    {
        return view('auth.register');
    }

    /**
     * Handle an incoming registration request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\RedirectResponse
     *
     * @throws \Illuminate\Validation\ValidationException
     */
    public function store(Request $request)
    {
        $request->validate([
            'fullname' => 'required|string|max:255',
            'username' => 'required|string|max:255',
            'email' => 'required|senter code heretring|email|max:255|unique:users',
            'phone' => 'required|string|max:255',
            'organization' => 'required|string|max:255',
            'community' => 'required|string|max:255',
            // 'phone' => 'required|string|max:255',
            'password' => 'required|string|min:8',
        ]);

        Auth::login($user = User::create([
            'fullname' => $request->fullname,
            'username' => $request->username,
            'email' => $request->email,
            'phone' => $request->phone,
            'organization_type' => $request->organization,
            'community_dev_auth_id' => $request->community,
            'password' => Hash::make($request->password),
        ]));
        

        event(new Registered($user));

        return redirect(RouteServiceProvider::HOME);
    }
}

用户模型文件。

<?php

namespace App\Models;

use Illuminate\Contracts\Auth\MustVerifyEmail;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Notifications\Notifiable;

class User extends Authenticatable
{
    use HasFactory, Notifiable;

    /**
     * The attributes that are mass assignable.
     *
     * @var array
     */
    protected $fillable = [
        'fullname',
        'username',
        'email',
        'phone',
        'organization',
        'community',
        'password',
    ];

    /**
     * The attributes that should be hidden for arrays.
     *
     * @var array
     */
    protected $hidden = [
        'password',
        'remember_token',
    ];

    /**
     * The attributes that should be cast to native types.
     *
     * @var array
     */
    protected $casts = [
        'email_verified_at' => 'datetime',
    ];
}

我已经运行了这个项目,但是它返回了这个错误:

SQLSTATE[42S02]:未找到基表或视图:1146 表 'ambulance_dubai.users' 不存在 (SQL: select count(*) as 从users 聚合,其中email = asdf@sdf.df)

【问题讨论】:

  • 这意味着您的数据库中没有 users 表。您确定要迁移吗?

标签: laravel-8


【解决方案1】:

由于您为用户模型使用不同的表名,因此您必须在模型中定义它。默认情况下,Laravel 会查找复数名称 如果您的模型没有表属性,则为模型(users)。

将此添加到用户模型中:

protected $table='tbl_user';

【讨论】:

    【解决方案2】:

    首先,您将检查用户表是否已迁移,用户表未迁移 使用这个命令

    php artisan migrate
    

    打开你的User Model

    并添加$table

    class User extends Authenticatable {
      protected $table = 'users';
    }
    

    【讨论】:

      【解决方案3】:

      另一个原因可能是验证表的名称不同。例如,在验证中使用表 tbl_users 可能存在错误并具有: 'required|unique:tbl_user,email'.

      缺少字母“s”,会抛出错误。

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2018-03-16
        • 1970-01-01
        • 2016-07-15
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多