Любой способ использовать команду SPOOL SQLPLUS с использованием cx_Oracle, SQL-клиента Python?

Я пытаюсь выполнить SQL-скрипт с помощью cx_Oracle, который примерно выглядит как

SPOOL /tmp/test.log SET echo ON SET serveroutput ON SIZE UNLIMITED BEGIN #SOME_PL/SQL_STATEMENTS END; / SPOOL OFF

где я пытаюсь записать результат операторов PL / SQL в файл. Я узнал, что команды SQLPlus не поддерживаются в cx_Oracle. Есть ли способ использовать SPOOL с помощью cx_Oracle?

что, если вы пошли другим путем - используя Python в своем SQLcl (современные команды SQLПлюс) сценарий? blogs.oracle.com/letthesunshinein/… у вас будет полный доступ к SQLPlus на основе Java, такие как SPOOL

thatjeffsmith 04.10.2018 13:53

Можно ли использовать Jython вместо Python? Если да, то могу привести пример.

Kris Rice 04.10.2018 14:31

Или почему бы просто не использовать файловые объекты Python?

Kaushik Nayak 04.10.2018 15:28

@KrisRice Пожалуйста, сделай.

Sathyanarayanan Ganesan 04.10.2018 16:45

@KaushikNayak Такой вариант есть. Просто хочу изучить и другие варианты.

Sathyanarayanan Ganesan 04.10.2018 16:46
Почему в Python есть оператор "pass"?
Почему в Python есть оператор "pass"?
Оператор pass в Python - это простая концепция, которую могут быстро освоить даже новички без опыта программирования.
Некоторые методы, о которых вы не знали, что они существуют в Python
Некоторые методы, о которых вы не знали, что они существуют в Python
Python - самый известный и самый простой в изучении язык в наши дни. Имея широкий спектр применения в области машинного обучения, Data Science,...
Основы Python Часть I
Основы Python Часть I
Вы когда-нибудь задумывались, почему в программах на Python вы видите приведенный ниже код?
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
Алиса и Боб имеют неориентированный граф из n узлов и трех типов ребер:
Оптимизация кода с помощью тернарного оператора Python
Оптимизация кода с помощью тернарного оператора Python
И последнее, что мы хотели бы показать вам, прежде чем двигаться дальше, это
Советы по эффективной веб-разработке с помощью Python
Советы по эффективной веб-разработке с помощью Python
Как веб-разработчик, Python может стать мощным инструментом для создания эффективных и масштабируемых веб-приложений.
0
5
774
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Нет прямого способа использовать SPOOL в cx_Oracle.

Проблема в том, что SPOOL - это специфическая команда SQL * PLUS. Это не команда Oracle SQL. Таким образом, фактическая буферизация выполняется на стороне клиента. Когда ты делаешь что-то вроде

SPOOL ON
SET PAGESIZE 0
SET SERVEROUTPUT ON
COLUMN username FORMAT A20

все эти команды являются командами SQL * PLUS, локальными (клиентскими) командами, и они не отправляются на сервер Oracle и не изменяют поведение сеанса Oracle вообще.

Эти команды предназначены только для управления тем, как вывод с сервера Oracle будет отображаться на экране (или записываться в файл или на принтер в случае SPOOL).

Вы можете идентифицировать локальную команду по тому факту, что ее не нужно заканчивать точкой с запятой ; (в большинстве случаев).

Полный справочник команд SQL * PLUS можно найти здесь: https://docs.oracle.com/database/121/SQPUG/ch_twelve001.htm#SQPUG023

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