yes or

db.define_table('Person',
                Field('name',length=45),
                Field('info','text'),
                format = '%(name)s', #### <<< gives you automatic
validator
                migrate=False)

db.define_table('Activity',
                Field('type',length=45),
                Field('start_date','date'),
                Field('end_date','date'),
                Field('money',length=45),
                Field('price','double'),
                Field('person_id',db.Person))
                Field('extra_info',length=45),
                Field('owner_user_id',length=4),
                Field('hour','double'),
                       migrate=False)

On Jan 17, 9:26 pm, Jeff Bauer <jba...@rubic.com> wrote:
> Gibran,
>
> Just use db.Person, not db.Person.id:
>
>    Field('person_id',db.Person)
>
> You can then specify the dropdown:
>
>    db.Activity.person_id.requires = IS_IN_DB(db,
>                                         'Person.id',
>                                         '%(id)s %(name)s',)
>
> Or formatted however you want it to appear.
>
> BTW: The convention would probably be to use 'person'
> as your field name in Activity, rather than 'person_id'.
>
> Jeff Bauer
> Rubicon, Inc.
>
> On 01/17/2010 08:20 PM, Gibran Rodriguez wrote:
>
> > I have 2 tables
>
> > db.define_table('Person',
> >                  Field('name',length=45),
> >                  Field('info','text'),
> >                  migrate=False)
>
> > db.define_table('Activity',
> >                  Field('type',length=45),
> >                  Field('start_date','date'),
> >                  Field('end_date','date'),
> >                  Field('money',length=45),
> >                  Field('price','double'),
> >                  Field('person_id',db.Person.id <http://db.Person.id>))
> >                  Field('extra_info',length=45),
> >                  Field('owner_user_id',length=4),
> >                  Field('hour','double'),
> >                         migrate=False)
>
> > so I want to use the Person.id for the field person_id in the table
> > Activity so that I get a drop downlist of the existing ids but I get the
> > following error?
>
> > File "/home/brangi/Desktop/web2py/gluon/sql.py", line 1242, in define_table
> >      t = self[tablename] = Table(self, tablename, *fields)
> >    File "/home/brangi/Desktop/web2py/gluon/sql.py", line 1476, in __init__
> >      if field.type == 'id':
> >    File "/home/brangi/Desktop/web2py/gluon/sql.py", line 2383, in __eq__
> >      return Query(self, '=', value)
> >    File "/home/brangi/Desktop/web2py/gluon/sql.py", line 2788, in __init__
> >      right = sql_represent(right, left.type, left._db._dbname,
> > left._db._db_codec)
> >    File "/home/brangi/Desktop/web2py/gluon/sql.py", line 502, in
> > sql_represent
> >      return str(int(obj))
> > ValueError: invalid literal for int() with base 10: 'id'
>
> > --
> > You received this message because you are subscribed to the Google
> > Groups "web2py-users" group.
> > To post to this group, send email to web...@googlegroups.com.
> > To unsubscribe from this group, send email to
> > web2py+unsubscr...@googlegroups.com.
> > For more options, visit this group at
> >http://groups.google.com/group/web2py?hl=en.
>
>
-- 
You received this message because you are subscribed to the Google Groups 
"web2py-users" group.
To post to this group, send email to web...@googlegroups.com.
To unsubscribe from this group, send email to 
web2py+unsubscr...@googlegroups.com.
For more options, visit this group at 
http://groups.google.com/group/web2py?hl=en.


Reply via email to