小编Mup*_*sat的帖子

从SqlAlchemy调用MSSQL存储过程

看起来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
Run Code Online (Sandbox Code Playgroud)

这有效:

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()
Run Code Online (Sandbox Code Playgroud)

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

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'])
Run Code Online (Sandbox Code Playgroud)

谢谢.

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

cursor = engine.raw_connection().cursor()
cursor.execute("list_lock_set ?, ?", ['bbc', 'using cursor'])
cursor.commit()
Run Code Online (Sandbox Code Playgroud)

我也可以获得pyodbc连接:

engine.raw_connection().connection
Run Code Online (Sandbox Code Playgroud)

并设置 …

python sql-server stored-procedures sqlalchemy

6
推荐指数
2
解决办法
5474
查看次数

如何使用 SQLAlchemy TypeDecorator 向列添加方法

我正在尝试向 ORM 类成员添加自定义方法,以使其处理与该成员相关的事物。尝试遵循文档

class EnhDateTime(types.TypeDecorator):
    impl = types.DateTime
    def foo(self):
        return "foo"

class MyDoc(Base):
     id = Column(Integer, primary_key=True,  autoincrement=False) 
     created = Column(EnhDateTime)

doc = session.query(MyDoc).filter_by(id=123).one()
Run Code Online (Sandbox Code Playgroud)

不幸的是,什么也没发生,成员仍然是 DateTime 类型:

type(doc.created)
Run Code Online (Sandbox Code Playgroud)

日期时间.日期时间

doc.created.foo()
Run Code Online (Sandbox Code Playgroud)

属性错误

python sqlalchemy

4
推荐指数
1
解决办法
5669
查看次数