Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/290.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python SQLAlchemy会话错误_Python_Session_Sqlalchemy_Add - Fatal编程技术网

Python SQLAlchemy会话错误

Python SQLAlchemy会话错误,python,session,sqlalchemy,add,Python,Session,Sqlalchemy,Add,我对SQLAlchemy中的会话有一个问题,当我在DB中添加一行时可以,但是如果我想在不关闭应用程序的情况下添加另一行,它不会添加 这是我的模型中的函数: def add(self,name): self.slot_name = name our_slot = self.session_.query(Slot).filter_by(slot_name = str(self.slot_name)).first() if our_slot: return 0

我对SQLAlchemy中的会话有一个问题,当我在DB中添加一行时可以,但是如果我想在不关闭应用程序的情况下添加另一行,它不会添加

这是我的模型中的函数:

def add(self,name):
    self.slot_name = name
    our_slot = self.session_.query(Slot).filter_by(slot_name = str(self.slot_name)).first()
    if our_slot:
        return 0
    else:
        self.session_.add(self)
        self.session_.commit()
        return 1

问题是您提交了会话。提交会话后,它将关闭。要么在完成添加后提交,要么在每次提交后打开一个新会话。还要看一下
Session.commit()
。您可能应该在中阅读有关会话的内容

此外,建议您这样做:

def add(self,name):
    self.slot_name = name
    try:
        our_slot = self.session_.query(Slot)\
        .filter_by(slot_name = str(self.slot_name)).one()
        self.session_.add(self)
        return 1
    except NoResultFound:
        return 0

当然,这只有在您只期望一个结果时才有效。提出异常并捕获它们而不是编造条件被认为是一种良好的做法。

试试这两个名字:“Pacey Ennis”、“Silvanus Yuliy”。它们都被添加了吗?谢谢,但这并没有解决我的问题,当我先添加“A”,然后添加“B”时,“A”的行被“B”覆盖。我解决了在控制器中更新对象的问题。