在sqlalchemy中添加一个带有关系的对象

时间:2013-04-28 07:54:51

标签: python-2.7 sqlalchemy

我想使用关系将一个对象添加到数据库中,代码是打击:

代码在eclipse中运行,数据库是postgresql

from sqlalchemy import Table, MetaData, Column, ForeignKey, Integer, String, Sequence
from sqlalchemy.orm import mapper, relationship, backref
from sqlalchemy.engine import create_engine
from sqlalchemy.orm.session import sessionmaker

创建引擎和会话

engine = create_engine("postgresql+psycopg2://openpg:openpgpwd@localhost:5432/testdb", echo=True)
Session = sessionmaker(bind = engine)
session = Session()
metadata = MetaData()

创建用户和地址类

user = Table('user', metadata,
             Column('id',Integer,Sequence('user_id_seq'),primary_key=True),
             Column('name',String(50)),
             Column('fullname',String(50)),
             Column('password',String(12)))

class User(object):
    def __init__(self, name, fullname, password):
        self.name = name
        self.fullname = fullname
        self.password = password

address = Table('address', metadata,
                Column('id', Integer,Sequence('address_id_seq'),primary_key=True),
                Column('user_id',Integer,ForeignKey('user.id')),
                Column('email_address',String(50)))

class Address(object):
    def __init__(self, user_id, email_address):
        self.user_id = user_id
        self.email_address = email_address

mapper(User,user,properties = {'addresses': relationship(Address, backref=backref('user',order_by=address.c.id))})        
mapper(Address, address)

if __name__ == '__main__':
    jack = User('jack', 'Jack Bean', 'gjffdd')
    jack.addresses = [Address(email_address='jack@google.com'),Address  (email_address='jack@yahoo.com')]
    session.add(jack)
    session.commit()

在eclipse中运行,结果是:

 Traceback (most recent call last):
  File "D:\workspace\test1\dbtest\testrelationship.py", line 68, in <module>
    jack.addresses = [Address(email_address='jack@google.com'),Address   (email_address='jack@yahoo.com')]
TypeError: __init__() takes exactly 3 arguments (2 given)

我不知道如何解决问题,谢谢!

1 个答案:

答案 0 :(得分:0)

您没有向user_id提供Address.__init__参数。所以摆脱它:

class Address(object):
    def __init__(self, email_address):
        self.email_address = email_address
无论如何,SA将负责将正确的值存储在数据库中。