appService = new AppService; parent::__construct(); } protected function configure() { $this->setDescription('Select rows form a table.'); $this->addArgument('table', InputArgument::REQUIRED, 'The table name.'); } /** * @param InputInterface $input * @param OutputInterface $output * @return int * @throws \YandexCloud\Ydb\Exception */ protected function execute(InputInterface $input, OutputInterface $output) { $table_name = $input->getArgument('table') ?: ''; $ydb = $this->appService->initYdb(); $result = $ydb->table()->retrySession(function (Session $session) use ($table_name, $output) { return $session->query('select * from `' . $table_name . '` limit 10;'); }, true); $output->writeln('Column count: ' . $result->columnCount()); $output->writeln('Row count: ' . $result->rowCount()); $t = new Table($output); $t ->setHeaders(array_map(function($column) { return $column['name']; }, $result->columns())) ->setRows($result->rows()) ; $t->render(); return Command::SUCCESS; } }