В настоящее время я выполняю миграцию в Laravel через терминал и получаю эти две ошибки при попытке использовать php artisan migrate; Я распечатаю ошибки ниже:
BadMethodCallException : Method Illuminate\Database\Schema\Blueprint::int does not exist.
at /Users/shaquilenoor/Desktop/chatapi/vendor/laravel/framework/src/Illuminate/Support/Traits/Macroable.php:100
96| */
97| public function __call($method, $parameters)
98| {
99| if (! static::hasMacro($method)) {
> 100| throw new BadMethodCallException(sprintf(
101| 'Method %s::%s does not exist.', static::class, $method
102| ));
103| }
104|
Exception trace:
1 Illuminate\Database\Schema\Blueprint::__call("int")
/Users/shaquilenoor/Desktop/chatapi/database/migrations/2019_01_29_045824_create_contacts_table.php:15
2 CreateContactsTable::{closure}(Object(Illuminate\Database\Schema\Blueprint))
/Users/shaquilenoor/Desktop/chatapi/vendor/laravel/framework/src/Illuminate/Database/Schema/Builder.php:164
Похоже, что обе ошибки связаны с моей таблицей CreateContactsTable, поэтому я распечатаю код из этого файла ниже:
use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;
class CreateContactsTable extends Migration
{
public function up()
{
Schema::create('contacts', function (Blueprint $table) {
$table->increments('id');
$table->unsignedInteger('user1_id');
$table->unsignedInteger('user2_id');
$table->int('room_id')->unique();
$table->timestamps();
$table->foreign('room_id')->references('id')->on('rooms');
$table->foreign('user1_id')->references('id')->on('users');
$table->foreign('user2_id')->references('id')->on('users');
});
}
public function down()
{
Schema::dropIfExists('contacts');
}
}






Ошибка в строке:
$table->int('room_id')->unique();
Метода int не существует. Вместо этого вы должны использовать integer:
$table->integer('room_id')->unique();
Измените $table->int на $table->integer, потому что метод int не существует
Спасибо! Эта ошибка исчезла, но теперь у меня есть новая проблема, я напечатаю ниже: PDOException::("SQLSTATE[HY000]: Общая ошибка: 3780 Ссылочный столбец "room_id" и ссылочный столбец "id" в ограничении внешнего ключа "contacts_room_id_foreign" несовместимо.") /Users/shaquilenoor/Desktop/chatapi/vendor/laravel/framework/src/Illuminate/Database/Connection.php:458 2 PDOStatement::execute() /Users/shaquilenoor/Desktop/chatapi /vendor/laravel/framework/src/Illuminate/Database/Connection.php:458
Привет, @Chakeeel, ты определил столбец id в таблице rooms как первичный или уникальный ключ?
Спасибо! Эта ошибка исчезла, но теперь у меня есть новая проблема, я напечатаю ниже: PDOException::("SQLSTATE[HY000]: Общая ошибка: 3780 Ссылочный столбец "room_id" и ссылочный столбец "id" в ограничении внешнего ключа "contacts_room_id_foreign" несовместимо.") /Users/shaquilenoor/Desktop/chatapi/vendor/laravel/framework/src/Illuminate/Database/Connection.php:458 2 PDOStatement::execute() /Users/shaquilenoor/Desktop/chatapi /vendor/laravel/framework/src/Illuminate/Database/Connection.php:458