这个断言是否总是通过?换句话说,当将新对象添加到会话中时,SQLAlchemy是否保存顺序(在生成INSERT查询时)?
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm.session import sessionmaker
from sqlalchemy.engine import create_engine
from sqlalchemy.types import Integer
from sqlalchemy.schema import Column
engine = create_engine('sqlite://')
Base = declarative_base(engine)
Session = sessionmaker(bind=engine)
session = Session()
class Entity(Base):
__tablename__ = 'entity'
id = Column(Integer(), primary_key=True)
Entity.__table__.create(checkfirst=True)
first = Entity()
session.add(first)
second = Entity()
session.add(second)
session.commit()
assert second.id > first.id
print(first.id, second.id)
在生产环境中我使用PostgreSQL,SQLite仅用于测试。
dict
和set
出现在很多地方),也无法提供一个令人信服的反例(除了序列中的非单调性),所以 +1。 - SingleNegationElimination