Python 通过sqlalchemy在执行时启用执行多个语句

Python 通过sqlalchemy在执行时启用执行多个语句,python,mysql,sqlalchemy,Python,Mysql,Sqlalchemy,我有一个DDL对象(create\u function\u foo),它包含一个create function语句。在它的第一行,我把DROP函数(如果存在foo)但引擎。执行(创建函数\u foo)返回: sqlalchemy.exc.InterfaceError: (InterfaceError) Use multi=True when executing multiple statements 我将multi=True作为create\u engine、engine.execute\u

我有一个DDL对象(
create\u function\u foo
),它包含一个create function语句。在它的第一行,我把
DROP函数(如果存在foo)
引擎。执行(创建函数\u foo)
返回:

sqlalchemy.exc.InterfaceError: (InterfaceError) Use multi=True when executing multiple statements
我将
multi=True
作为
create\u engine
engine.execute\u options
engine.execute
的参数,但它不起作用

注意
引擎
如果我的
实例创建引擎

注意:我使用的是python 3.2+mysql.connector 1.0.12+sqlalchemy 0.8.2

create_function_foo = DDL("""\
DROP FUNCTION IF EXISTS foo;
CREATE FUNCTION `foo`(
    SID INT
) RETURNS double
READS SQL DATA
BEGIN
  ...
END
""")

我应该把它放在哪里?

multi=True
是MySql连接器的要求。不能将此标志传递给SQLAlchemy方法。这样做:

conn  = session.connection().connection
cursor = conn.cursor()  # get mysql db-api cursor
cursor.execute(sql, multi=True)

此处的更多信息:

在某些情况下,SQLAlchemy在访问某些
DBAPI
函数时不提供通用方法,例如处理多个结果集。在这些情况下,您应该直接处理原始DBAPI连接

:


嗯。。。对我来说,这似乎是个麻烦。我不想使用ORM,所以接受的答案对我不起作用

我改为:

with open('sql_statements_file.sql') as sql_file:
    for statement in sql_file.read().split(';'):
        if len(statement.strip()) > 0:
             connection.execute(statement + ';')

然后创建函数的操作失败了。。。。YMMV.

sqlalchemy解决方案似乎不起作用。一个查询有效,两个查询抛出编程错误。sqlalchemy API中是否有变化?将脚本拆分为语句的更可靠方法是使用SQL解析库,例如
sqlparse.split(sqlparse.format(self.SQL,strip\u comments=True))
operation = 'SELECT 1; INSERT INTO t1 VALUES (); SELECT 2'
for result in cursor.execute(operation, multi=True):
  if result.with_rows:
    print("Rows produced by statement '{}':".format(
      result.statement))
    print(result.fetchall())
  else:
    print("Number of rows affected by statement '{}': {}".format(
      result.statement, result.rowcount))
with open('sql_statements_file.sql') as sql_file:
    for statement in sql_file.read().split(';'):
        if len(statement.strip()) > 0:
             connection.execute(statement + ';')