Files
investbrain/database/migrations/2021_09_06_014744_create_holdings_table.php
T

42 lines
1.2 KiB
PHP
Raw Normal View History

2024-08-03 14:21:29 -05:00
<?php
use App\Models\Portfolio;
2024-08-10 13:30:34 -05:00
use App\Models\MarketData;
2024-08-03 14:21:29 -05:00
use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;
class CreateHoldingsTable extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('holdings', function (Blueprint $table) {
$table->uuid('id')->primary();
2024-08-10 13:30:34 -05:00
$table->foreignIdFor(Portfolio::class, 'portfolio_id')->constrained()->onDelete('cascade');
$table->foreignIdFor(MarketData::class, 'symbol');
2024-08-03 14:21:29 -05:00
$table->float('quantity', 12, 4);
$table->float('average_cost_basis', 12, 4)->default(0);
$table->float('total_cost_basis', 12, 4)->default(0);
$table->float('realized_gain_dollars', 12, 4)->default(0);
$table->float('dividends_earned', 12, 4)->default(0);
2024-08-10 13:30:34 -05:00
$table->timestamp('splits_synced_at')->nullable();
2024-08-03 14:21:29 -05:00
$table->timestamps();
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::dropIfExists('holdings');
}
}