您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

python – 从SqlAlchemy调用MSSQL存储过程

5b51 2022/1/14 8:21:54 python 字数 2960 阅读 697 来源 www.jb51.cc/python

看起来SqlAlchemy似乎不支持调用存储过程.有没有人找到适用于SQL Server的解决方法?样品程序:CREATE PROCEDURE list_lock_set @name varchar (5), @requester varchar(30) AS BEGIN SET NOCOUNT ON; INSERT INTO list_lo

概述

看起来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 ?,'sqlalchemy'])

谢谢.

编辑:似乎最好的解决方案是从引擎中删除pyodbc游标:

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

我也可以获得pyodbc连接:

engine.raw_connection().connection

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

此外,我在MSsql过去遇到了一些问题,这似乎是由于在程序完成之前方法返回的异步事件,导致数据库出现不可预测的结果.我发现在调用之后立即设置time.sleep(1)(或任何适当的数字).

总结

以上是编程之家为你收集整理的python – 从SqlAlchemy调用MSSQL存储过程全部内容,希望文章能够帮你解决python – 从SqlAlchemy调用MSSQL存储过程所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶