- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试在 Oracle 数据库上执行 SQL 脚本(从文件中读取)。我尝试了很多方法,但都没有用。
我有以下方法:
def connect_cx_oracle():
dns_tns = cx_Oracle.makedsn(config.DB_HOST, config.DB_PORT, service_name=config.DB_DBASE)
con = cx_Oracle.connect(user=config.DB_USERNAME, password=config.DB_PASSWORD, dsn=dns_tns)
cur = con.cursor()
fd = open('PurgeProcess_2.sql')
full_sql = fd.read()
cur.prepare(full_sql)
cur.executemany(None, full_sql)
con.commit()
对文件使用 cur.execute 会导致错误。我不能用分号分割文件,因为它是一个脚本。
sql文件的代码是这样的(不是发布整个文件)
SET SERVEROUTPUT ON SIZE UNLIMITED;
DECLARE
CURSOR c_task IS SELECT job_id, task_info_id FROM task WHERE job_id <= myjob_id;
BEGIN
dbms_output.ENABLE(NULL);
dbms_output.put_line('*******************************');
dbms_output.put_line('* Purge job started....... ');
dbms_output.put_line('*******************************');
IF (FROM_date < 30) THEN
dbms_output.put_line(' ');
end IF;
EXCEPTION
WHEN NO_DATA_FOUND THEN
dbms_output.put_line(' ');
dbms_output.put_line('*******************************');
dbms_output.put_line('* Purge job completed....... ');
dbms_output.put_line('*******************************');
RAISE NO_ITEMS_TO_PROCESS;
END;
FOR i IN 1..myjobIDnumber.COUNT
LOOP
BEGIN
DELETE FROM job WHERE id = myjobIDnumber(i);
IF SQL%ROWCOUNT > 0 THEN
deletecount4 := deletecount4 + SQL%ROWCOUNT;
END IF;
END;
END LOOP;
dbms_output.put_line('Job table records deleted. Number of records deleted is ' || deletecount4);
dbms_output.put_line(' ');
ROLLBACK;
--COMMIT;
dbms_output.put_line('*******************************');
dbms_output.put_line('* Purge job completed....... *');
dbms_output.put_line('*******************************');
EXCEPTION
WHEN NO_ITEMS_TO_PROCESS THEN
NULL;
WHEN DATE_LIMIT_APPROACHED THEN
NULL;
END;
如果我使用 cur.execute(fileName) 我得到
cx_Oracle.DatabaseError: ORA-00922: missing or invalid option
有了 executemany,我得到了
TypeError: parameters should be a list of sequences/dictionaries or an integer specifying the number of times to execute the statement
我不是真正的 sql 专家,任何帮助将不胜感激。问候
最佳答案
cx_Oracle 和其他类似驱动只能execute one statement一次。连executemany()
执行一条语句(但有很多数据值)。
做你想做的最简单的方法是:
从您的 SQL 文件中删除所有 SQL*Plus 特定命令,例如 SET
,因为如果 cx_Oracle 尝试执行它们,数据库将无法理解它们。它们对 cx_Oracle 毫无意义。
始终使用斜线(而不是分号)来终止 SQL 命令(以及 PL/SQL,当然斜线始终是必需的)
写一个类似RunSqlScript的方法从您的 SQL 文件中读取每个语句并执行它。
一个更明智的解决方案是远离 SQL 文件并在 cx_Oracle 中编写所有语句。
关于python - 如何使用 cx_oracle 执行 SQL 脚本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57876133/
我为此苦了一个星期。我正在尝试运行一个使用即时客户端版本11.2.0.3.0与远程Oracle数据库连接的python flask应用程序。 在遇到许多问题之后,我结束了使用3个buildpack,其
以下语句中字典中的 bindind 日期有问题吗?? mySQL = 'SELECT day_key FROM timeday WHERE calendar_date =:calendar' args
我尝试在 Ubuntu 上使用 crontab 运行 python scrapy 爬虫,但收到以下错误消息: Traceback (most recent call last): File "/u
我正在使用 Amazon Work Space,并且我使用 VPN 通过 SSH Ubuntu 16.04 实例进行连接。我使用 python 来连接 Oracle 数据库 11g,我需要使用 cx_
在我的 Python 代码中,当我要求用户输入一个字符串以进行 SELECT 时,它起作用了,但是当我尝试使用相同输入的 UPDATE 时,不允许我执行 这是连接成功后的代码 curs = conne
在我的 Python 代码中,当我要求用户输入一个字符串以进行 SELECT 时,它起作用了,但是当我尝试使用相同输入的 UPDATE 时,不允许我执行 这是连接成功后的代码 curs = conne
我正在尝试使用 python 中的 cx_Oracle 连接到 oracle 数据库。我能够连接到数据库并提取数据。 现在我正在尝试连接到另一个数据库,我必须首先调用安全过程,然后只有我才能看到基础表
对于我创建的 Oracle 表 MYTABLE,我有一个列 COL1,它被声明为 NUMBER(20,3);小数点后可以有 3 位有效数字。当我在此表上运行 cx_Oracle 游标时: cursor
我正在使用 web.py 从 Oracle 创建一个简单的报告页面。当我采用使用 vars= 传递参数的最佳实践方法时,延迟为 11-12 秒。当我使用字符串替换执行相同的查询时,查询会在不到一秒的时
我正在尝试在 python 中使用 cx_Oracle 并行运行完全独立的 Oracle 查询。 我可以通过为每个线程设置一个新的数据库连接,然后在每个单独的线程中运行查询来成功地完成这项工作,这使总
为什么下面的代码不起作用?它返回零行,即使我有很多匹配搜索条件的行。 select * from Table_1 形式的简单查询工作正常并返回正数行 import cx_Oracle def func
在最新版本的 python 中,可以使用类似 with open('abc.txt') as f: 的东西来保证文件被关闭,即使在以下(缩进)中发生异常) 代码块。我想知道这种技术是否也适用于 cx_
我正在使用 cx_oracle python 库来查找过去 90 分钟内具有 ModifiedDate 的任何记录。 import cx_Oracle import datetime from dat
我正在尝试连接到 Oracle 数据库,但出现以下错误: curcon = cx_Oracle.connect(conn_str) cx_Oracle.DatabaseError: ORA-12170
我正在运行... SQL*Plus: Release 9.2.X.X.X - Production on Wed Jun 22 13:02:14 2011 Copyright (c) 1982, 20
Code Oracle: Procedure example ( p_Cod_Rspta out varchar2 , p_e
在 Java DataSource 中实现了一个用于数据库访问的 Java 范例。该对象围绕数据库连接的创建创建了一个有用的抽象。 DataSource 对象保留数据库配置,但只会根据请求创建数据库连
我正在使用 cx_Oracle 访问我们的数据库。我希望用户能够输入电台 ID,例如: stationID=(无论用户在提示时输入什么) cursor.execute('''select cruise
为了演示 Oracle 的安全特性,必须在用户 session 尚未建立时调用 OCIServerVersion() 或 OCIServerRelease()。 同时具有数据库参数 sec_retur
我正尝试在 Oracle 10 数据库中再次执行此操作: cursor = connection.cursor() lOutput = cursor.var(cx_Oracle.STRING) cur
我是一名优秀的程序员,十分优秀!