parent
edc8730198
commit
3406dc14f4
@ -0,0 +1,62 @@
|
||||
<?php
|
||||
|
||||
namespace App\Command;
|
||||
|
||||
use Doctrine\DBAL\Connection;
|
||||
use Symfony\Component\Console\Command\Command;
|
||||
use Symfony\Component\Console\Input\InputArgument;
|
||||
use Symfony\Component\Console\Input\InputInterface;
|
||||
use Symfony\Component\Console\Output\OutputInterface;
|
||||
|
||||
class PopulateDBCommand extends Command
|
||||
{
|
||||
protected static $defaultName = 'app:populateDB';
|
||||
|
||||
private Connection $connection;
|
||||
|
||||
public function __construct(Connection $connection)
|
||||
{
|
||||
parent::__construct();
|
||||
$this->connection = $connection;
|
||||
}
|
||||
|
||||
protected function configure()
|
||||
{
|
||||
$this
|
||||
->setDescription('Populate the database.');
|
||||
}
|
||||
|
||||
protected function execute(InputInterface $input, OutputInterface $output): int
|
||||
{
|
||||
try {
|
||||
|
||||
// On supprime la table si elle existe déjà
|
||||
$this->connection->executeStatement('DROP TABLE IF EXISTS rarity');
|
||||
|
||||
// On crée la table
|
||||
$this->connection->executeStatement('
|
||||
CREATE TABLE rarity (
|
||||
id INT PRIMARY KEY,
|
||||
name VARCHAR(255) NOT NULL,
|
||||
drop_rate FLOAT NOT NULL
|
||||
)
|
||||
');
|
||||
|
||||
// On peuple la table
|
||||
$this->connection->executeStatement("INSERT INTO rarity (id, name, drop_rate) VALUES
|
||||
(1, 'Common', 0.6),
|
||||
(2, 'Rare', 0.2),
|
||||
(3, 'Epic', 0.1),
|
||||
(4, 'Mythical', 0.085),
|
||||
(5, 'Legendary', 0.015)
|
||||
");
|
||||
|
||||
$output->writeln('Base de données peuplée.');
|
||||
} catch (\Exception $e) {
|
||||
$output->writeln('<error>Erreur : ' . $e->getMessage() . '</error>');
|
||||
return Command::FAILURE;
|
||||
}
|
||||
|
||||
return Command::SUCCESS;
|
||||
}
|
||||
}
|
Loading…
Reference in new issue