Эквивалент Python os.execvp для PHP

У меня запущена программа командной строки PHP. И я хочу подключиться к оболочке mysql прямо из PHP. Я делал это раньше в Python, используя os.execvp. Но я не могу заставить то же самое работать в PHP.

Я пробовал следующие функции:

  • система
  • пройти
  • exec
  • shell_exec

пример:

system('mysql -u root -pxxxx db_name');

Но все они, кажется, ждут, пока mysql выйдет и что-то вернет. Я действительно хочу, чтобы PHP запускал оболочку mysql, а затем сам выходил из нее. есть идеи?

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
4
0
570
3
Перейти к ответу Данный вопрос помечен как решенный

Ответы 3

Дайте MySQL запустить сценарий, отдельный от сценария PHP:

system('mysql -u root -pxxxx db_name < script.mysql');

В дополнение к тому, что сказал акросман, вы также можете использовать переключатель -e для передачи SQL из командной строки.

$sql = ".....";
system("mysql -u root -pxxxx db_name -e \"$sql\"");

Кроме того, я надеюсь, что вы на самом деле не подключаетесь к базе данных как root из приложения PHP.

Спасибо за подсказку, но это не то, что я ищу. Я хочу переместить пользователя из PHP cli в оболочку mysql.

Mattias 08.11.2008 17:07
Ответ принят как подходящий

Если вы хотите, чтобы команды оболочки были интерактивными, используйте:

system("mysql -uroot -p db_name > `tty`");

Это будет работать в большинстве случаев, но сломается, если вы не в терминале.

Блестяще! это именно то, что я искал!

Mattias 08.11.2008 17:08

Другие вопросы по теме