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/