python - 从 SqlAlchemy 调用 MSSQL 存储过程

标签 python sql-server stored-procedures sqlalchemy

SqlAlchemy 好像不支持调用存储过程。有人找到了适用于 SQL Server 的解决方法吗?

示例程序:

CREATE PROCEDURE list_lock_set @name varchar (5), @requester varchar(30)
AS
BEGIN
    SET NOCOUNT ON;
    INSERT INTO list_lock (name, requester, acquired) values (@name, @requester, GETDATE())
    RETURN 0    
END
GO

这个有效:

import pyodbc
dbh = pyodbc.connect(driver=''{SQL Server}'', server=srv, database=db, uid=uid, pwd=pwd)
dbc = dbh.cursor()
dbc.execute("list_lock_set ?, ?", ['bbc', 'pyodbc'])
dbc.commit()

这不会产生错误但也不起作用:

from sqlalchemy import create_engine
engine = create_engine('mssql+pyodbc://usr:passw@srv/db?driver=SQL Server', echo=True)
engine.execute("list_lock_set ?, ?", ['bbc', 'sqlalchemy'])

谢谢。

编辑:看来最好的解决方案是从引擎中取出 pyodbc 游标:

cursor = engine.raw_connection().cursor()
cursor.execute("list_lock_set ?, ?", ['bbc', 'using cursor'])
cursor.commit()

我也可以获得pyodbc连接:

engine.raw_connection().connection

并设置 autocommit=True,但这可能会干扰引擎逻辑。非常感谢@Batman。

最佳答案

为了让它在 sqlalchemy 中工作,我设法这样做了:

from sqlalchemy import create_engine
engine = create_engine('mssql+pyodbc://usr:passw@srv/db?driver=SQL Server', echo=True)
with engine.begin() as conn:
    conn.execute("exec dbo.your_proc")

关于python - 从 SqlAlchemy 调用 MSSQL 存储过程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40426536/

相关文章:

sql-server - 是否有用于匈牙利语的第三方 SQL Server 分词系统?

sql-server - SQL Server 存储过程无法通过 Codesmith 运行

sql-server - 无法批量加载,因为无法打开文件。操作系统错误代码 3

python - Scrapy Spider 在同一页面获取两张图片,然后以不同的方式命名它们

python - 在导入 python 时。 ImportError : libcublas. so.9.0: 无法打开共享对象文件: 没有那个文件或目录

sql-server - 如何在 SQL Server 2005 中从 IndexId 获取索引名称

sql - 动态 SQL 结果 INTO 临时表

oracle - PL/SQL过程错误

python - 根据numpy中的条件形成子数组

python - 将整数转换为其 ascii 值的字符串