SQLalchemy AttributeError: 'str' object n'a pas d'attribut "_sa_instance_state'
J'essaye d'ajouter un article à ma base de données avec SQLAlchemy + Python, mais reçois un message d'erreur.
Mon database_setup.py:
class company(Base):
__tablename__ = 'company'
compID = Column(Integer, primary_key = True)
name = Column(String(80), nullable = False)
class item(Base):
__tablename__ = 'items'
itemID = Column(Integer, primary_key = True)
name = Column(String(80), nullable = False)
category = Column(String(250))
description = Column(String(250))
price = Column(String(8))
compID = Column(Integer, ForeignKey('company.compID'))
company = relationship(company)
après l'importation de sqlalchemy à mon terminal, je définir un élément à insérer:
JawboneUP3 = item(
itemID="1",
name="Jawbone UP3",
description="The latest UP!",
category="tracker",
price="$174.99",
company="Jawbone"
)
et dessiner une session pour ajouter et valider:
session.add(JawboneUP3)
session.commit()
Quand je soumettre, je reçois cette erreur:
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/lib/python2.7/dist-packages/sqlalchemy/orm/session.py", line 1399, in add
self._save_or_update_state(state)
File "/usr/lib/python2.7/dist-packages/sqlalchemy/orm/session.py", line 1417, in _save_or_update_state
halt_on=self._contains_state):
File "/usr/lib/python2.7/dist-packages/sqlalchemy/orm/mapper.py", line 2037, in cascade_iterator
parent_dict, visited_states, halt_on))
File "/usr/lib/python2.7/dist-packages/sqlalchemy/orm/properties.py", line 932, in cascade_iterator
get_all_pending(state, dict_)
File "/usr/lib/python2.7/dist-packages/sqlalchemy/orm/attributes.py", line 761, in get_all_pending
ret = [(instance_state(current), current)]
AttributeError: 'str' object has no attribute '_sa_instance_state'
J'ai ajouté un 'Mâchoire' objet de mon entreprise table, ce que je comprends mon JawboneUP3 " doit se rapporter à. Cet objet a bien été ajouté par le biais d'un formulaire de navigateur que j'ai activé via mon serveur de script. Je crois que je dois être en mesure d'ajouter des éléments à droite de la borne.
OriginalL'auteur mleafer | 2015-10-12
Vous devez vous connecter pour publier un commentaire.
Je pense que le problème est dans la façon dont vous définissez la compagnie de schéma:
La
item
constructeur attend uncompany
instance, mais vous êtes de passage à une chaîne de valeur. Fix it:OriginalL'auteur alecxe
Tout d'abord, lors de la définition d'une classe en Python, il est de bonne pratique pour démarrer le nom avec une majuscule comme ceci:
Cela étant dit, il n'est pas pourquoi ton code génère une erreur. 🙂
La raison
La
Item
constructeur s'attend à une instance de l'objetCompany
par le passé en tant que valeur de la variablecompany
Solution 1: La Mâchoire société n'existe pas dans votre base de données
Voici la réponse de @alecxe est valide.
Vous devez remplacer votre code avec:
Ajouter cet objet à la session et comiting les changements seront effectivement rendre deux entrées de votre base de données:
Solution 2: La Mâchoire société existe dans votre base de données
Ici, vous devez chercher de l'entreprise Mâchoire à partir de votre tableau de "société" et de le passer en argument à la
Item
constructeur, comme ceci:Pour la
session
partie vérifier cetteOriginalL'auteur Arjjuna