6


id(整数主键)
数据(blob)

我使用 mysql 和 sqlalchemy。要插入数据,我使用:

o = Demo()
o.data = mydata
session.add(o)
session.commit()

我想像这样插入表格:

INSERT INTO table(data) VALUES(COMPRESS(mydata))

如何使用 sqlalchemy 做到这一点?

4

1 回答 1

1

您可以将 SQL 函数分配给属性:

from sqlalchemy import func
object.data = func.compress(mydata)
session.add(object)
session.commit()

这是一个使用更多与 DB 无关的 lower() 函数的示例:

from sqlalchemy import *
from sqlalchemy.orm import *
from sqlalchemy.ext.declarative import declarative_base

Base= declarative_base()

class A(Base):
    __tablename__ = "a"

    id = Column(Integer, primary_key=True)
    data = Column(String)

e = create_engine('sqlite://', echo=True)
Base.metadata.create_all(e)
s = Session(e)

a1 = A()
a1.data = func.lower("SomeData")
s.add(a1)
s.commit()

assert a1.data == "somedata"

您可以使用@validates 使其自动化:

from sqlalchemy.orm import validates
class MyClass(Base):
    # ...
    data = Column(BLOB)

    @validates("data")
    def _set_data(self, key, value):
        return func.compress(value)

如果您希望它在刷新之前在 python 中可读,您需要在本地存储它并使用描述符来访问它。

于 2012-06-13T14:18:17.257 回答