Postingan lainnya
PHP Artisan Migrate tidak Menghasilkan Kolom Apapun (kosong)
Pertama-tama, saya sudah coba buat table dulu dengan perintah
php artisan make:migration create_students_table
setelah itu pada directory file database/migrations/2024_03_16_160154_create_students_table.php muncul codingan sebagai berikut:
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
/**
* Run the migrations.
*/
public function up(): void
{
Schema::create('students', function (Blueprint $table) {
$table->id();
$table->string('name');
$table->integer('score');
$table->timestamps();
});
}
/**
* Reverse the migrations.
*/
public function down(): void
{
Schema::dropIfExists('students');
}
};
lalu saya juga cek pada file .env berisi codingan sebagai berikut, dan sudah benar sesuai informasi yang ada, dengan nama database laravel-11
APP_NAME=Laravel
APP_ENV=local
APP_KEY=base64:2linYqDNbm/ZyuoJJ/Gg0GAiGC9Fme+JmfP4qHKFiV8=
APP_DEBUG=true
APP_TIMEZONE=UTC
APP_URL=http://localhost
APP_LOCALE=en
APP_FALLBACK_LOCALE=en
APP_FAKER_LOCALE=en_US
APP_MAINTENANCE_DRIVER=file
APP_MAINTENANCE_STORE=database
BCRYPT_ROUNDS=12
LOG_CHANNEL=stack
LOG_STACK=single
LOG_DEPRECATIONS_CHANNEL=null
LOG_LEVEL=debug
DB_CONNECTION=sqlite
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=laravel-11
DB_USERNAME=root
DB_PASSWORD=
SESSION_DRIVER=database
SESSION_LIFETIME=120
SESSION_ENCRYPT=false
SESSION_PATH=/
SESSION_DOMAIN=null
BROADCAST_CONNECTION=log
FILESYSTEM_DISK=local
QUEUE_CONNECTION=database
CACHE_STORE=database
CACHE_PREFIX=
MEMCACHED_HOST=127.0.0.1
REDIS_CLIENT=phpredis
REDIS_HOST=127.0.0.1
REDIS_PASSWORD=null
REDIS_PORT=6379
MAIL_MAILER=log
MAIL_HOST=127.0.0.1
MAIL_PORT=2525
MAIL_USERNAME=null
MAIL_PASSWORD=null
MAIL_ENCRYPTION=null
MAIL_FROM_ADDRESS="hello@example.com"
MAIL_FROM_NAME="${APP_NAME}"
AWS_ACCESS_KEY_ID=
AWS_SECRET_ACCESS_KEY=
AWS_DEFAULT_REGION=us-east-1
AWS_BUCKET=
AWS_USE_PATH_STYLE_ENDPOINT=false
VITE_APP_NAME="${APP_NAME}"
yang aneh adalah ketika saya masukkan perintah 'php artisan migrate' dia sempat muncul seperti ini
vendor\laravel\framework\src\Illuminate\Database\Connection.php:565
PDOException::("SQLSTATE[HY000]: General error: 1 table "students" already exists")
2 vendor\laravel\framework\src\Illuminate\Database\Connection.php:565
PDO::prepare("create table "students" ("id" integer primary key autoincrement not null, "name" varchar not null, "score" intege
lalu saya coba dengan 3 command ini yang pertama 'php artisan migrate:fresh', kedua 'php artisan migrate:rollback', dan ketiga 'php artisan migrate:reset'. Dan setelah ketiga command tersebut saya coba, saya masukkan kembali 'php artisan migrate' dan tidak muncul apa2, tetapi ketika saya masukkan 'php artisan migrate:status' munculnya
Migration name ................................................................................................... Batch / Status
0001_01_01_000000_create_users_table .................................................................................... [1] Ran
0001_01_01_000001_create_cache_table .................................................................................... [1] Ran
0001_01_01_000002_create_jobs_table ..................................................................................... [1] Ran
2024_03_16_160154_create_students_table ................................................................................. [1] Ran << ini yang mau saya buat
Tapi ketika saya cek di localhost/phpmyadmin, tidak muncul kolom apa2 pada database saya yang namanya 'laravel-11', dia bilang tidak ada column, padahal sudah saya detailkan di function up pada database/migrations/2024_03_16_160154_create_students_table.php
Mohon bantuannya, terima kasih.
2 Jawaban:
menggunakan konfigurasi mysql
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=nama_database
DB_USERNAME=root
DB_PASSWORD=root
untuk DB_USERNAME dan DB_PASSWORD sesuaikan dengan konfigurasi mysql yang kamu gunakan
Perlu diingat bahwa Laravel 11 by-default menggunakan sqlite
jadi pada potongan kode kamu DB_CONNECTION=sqlite
gantilah ke mysql