我是Web2py的新手,无法理解故障单丢失的错误。 有人可以解释错误及其发生的原因吗?
这是门票:
票证ID
127.0.0.1.2012-08-29.01-43-16.edfb1953-fd71-4aa6-a768-815fe46fe273 'Expression'对象没有'strip'属性
回溯
Traceback (most recent call last): File "/home/user/Web2py/web2py/gluon/restricted.py", line 205, in restricted exec ccode in environment File "/home/user/Web2py/web2py/applications/SocialImage/models/db.py", line 12, in format = '%(title)s') File "/home/user/Web2py/web2py/gluon/dal.py", line 6320, in define_table polymodel=polymodel) File "/home/user/Web2py/web2py/gluon/dal.py", line 598, in create_table referenced = field.type[10:].strip() AttributeError: 'Expression' object has no attribute 'strip'
Error snapshot ('Expression' object has no attribute 'strip')
Function argument list (self=, table=, 'id': }>, migrate=True, fake_migrate=False, polymodel=None) Code listing sortable += 1 k = field.name if isinstance(field.type,SQLCustomType): ftype = field.type.native or field.type.type elif field.type.startswith('reference'): referenced = field.type[10:].strip() constraint_name = self.constraint_name(tablename, field.name) if hasattr(table,'_primarykey'): rtablename,rfieldname = referenced.split('.') rtable = table._db[rtablename]
CODE:
db = DAL("sqlite://storage.sqlite") db.define_table('user', Field('uname',unique=True), Field('name'), Field('email')) db.define_table('image', Field('title', unique=True), Field('file', 'upload'), Field('uploader_name', db.user.uname), format = '%(title)s') db.define_table('comment', Field('image_id', db.image), Field('authors', db.user.uname), Field('body', 'text')) db.user.email.requires=IS_EMAIL() db.user.uname.requires=IS_NOT_IN_DB(db,db.uname) db.user.name=IS_NOT_EMPTY() db.image.uploader.requires=IS_IN_DB(db,db.user.uname) db.comment.image_id.requires=IS_IN_DB(db,db.image.id,'%(title)s') db.comment.image_id.writable=db.comment.image_id.readable=False
答案 0 :(得分:1)
您正在错误地定义引用字段 - 它们应该引用表,而不是引用该表中的特定字段。例如,您有:
Field('uploader_name', db.user.uname)
应该是:
Field('uploader_name', db.user)
注意,引用字段不会存储来自用户表的实际uname - 它将存储来自user表的引用记录的id。根据该参考,您可以在需要时获得uname。
此外,即将发布的web2py 2.0版本包含一个新的“懒惰表”功能,可以懒惰地定义表(完整定义推迟到第一次通过db.tablename引用访问表时)。因此,为了保持表的惰性,定义引用字段的首选方法是:
Field('uploader_name', 'reference user')
这可以避免使用db.user
,这会立即强制定义用户表。
最后,为引用的表添加“format”属性是个好主意 - 默认情况下,引用字段使用引用表的“format”属性来确定如何在表单drop中显示字段的值-down,网格/表格和只读表格。对于用户表,您可以执行以下操作:
db.define_table('user',
Field('uname',unique=True),
Field('name'),
Field('email'),
format='%(uname)s')
在这种情况下,引用用户表的所有字段都将显示uname值而不是基础记录id(即使引用字段本身将存储记录ID)。