5 * Contains \Drupal\Console\Command\Database\QueryCommand.
9 * - mysql -H option for html
10 * - mysql -X option for xml
13 namespace Drupal\Console\Command\Database;
15 use Symfony\Component\Console\Input\InputArgument;
16 use Symfony\Component\Console\Input\InputInterface;
17 use Symfony\Component\Console\Input\InputOption;
18 use Symfony\Component\Console\Output\OutputInterface;
19 use Symfony\Component\Process\ProcessBuilder;
20 use Symfony\Component\Console\Command\Command;
21 use Drupal\Console\Core\Command\Shared\CommandTrait;
22 use Drupal\Console\Command\Shared\ConnectTrait;
23 use Drupal\Console\Core\Style\DrupalStyle;
25 class QueryCommand extends Command
33 protected function configure()
36 ->setName('database:query')
37 ->setDescription($this->trans('commands.database.query.description'))
40 InputArgument::REQUIRED,
41 $this->trans('commands.database.query.arguments.query')
45 InputArgument::OPTIONAL,
46 $this->trans('commands.database.query.arguments.database'),
49 ->addOption('quick', null, InputOption::VALUE_NONE, $this->trans('commands.database.query.options.quick'))
50 ->addOption('debug', null, InputOption::VALUE_NONE, $this->trans('commands.database.query.options.debug'))
51 ->addOption('html', null, InputOption::VALUE_NONE, $this->trans('commands.database.query.options.html'))
52 ->addOption('xml', null, InputOption::VALUE_NONE, $this->trans('commands.database.query.options.xml'))
53 ->addOption('raw', null, InputOption::VALUE_NONE, $this->trans('commands.database.query.options.raw'))
54 ->addOption('vertical', null, InputOption::VALUE_NONE, $this->trans('commands.database.query.options.vertical'))
55 ->addOption('batch', null, InputOption::VALUE_NONE, $this->trans('commands.database.query.options.batch'))
57 ->setHelp($this->trans('commands.database.query.help'));
63 protected function execute(InputInterface $input, OutputInterface $output)
65 $io = new DrupalStyle($input, $output);
67 $query = $input->getArgument('query');
68 $database = $input->getArgument('database');
69 $learning = $input->getOption('learning');
71 $databaseConnection = $this->resolveConnection($io, $database);
73 $connection = sprintf(
74 '%s -A --database=%s --user=%s --password=%s --host=%s --port=%s',
75 $databaseConnection['driver'],
76 $databaseConnection['database'],
77 $databaseConnection['username'],
78 $databaseConnection['password'],
79 $databaseConnection['host'],
80 $databaseConnection['port']
83 $args = explode(' ', $connection);
84 $args[] = sprintf('--execute=%s', $query);
86 $opts = ["quick", "debug", "html", "xml", "raw", "vertical", "batch"];
88 $opts, function ($opt) use ($input, &$args) {
89 if ($input->getOption($opt)) {
123 $processBuilder = new ProcessBuilder([]);
124 $processBuilder->setArguments($args);
125 $process = $processBuilder->getProcess();
126 $process->setTty('true');
129 if (!$process->isSuccessful()) {
130 throw new \RuntimeException($process->getErrorOutput());