我似乎找不到修改通过以下方式创建的表单的方法:
from gluon.tools import Crud
crud = Crud(globals(), db)
form = crud.create(db.table_name)
由于我在表中使用外键,自动生成的表单只允许一个整数(表示外主键),但我想要做的是输入外数据字段需要的任何数据类型(而不是只是标识符)。有没有一种简单的方法来告诉create()函数使用外部表的数据类型而不是主表的数据类型(即自动递增的主键)?
我似乎找不到修改通过以下方式创建的表单的方法:
from gluon.tools import Crud
crud = Crud(globals(), db)
form = crud.create(db.table_name)
由于我在表中使用外键,自动生成的表单只允许一个整数(表示外主键),但我想要做的是输入外数据字段需要的任何数据类型(而不是只是标识符)。有没有一种简单的方法来告诉create()函数使用外部表的数据类型而不是主表的数据类型(即自动递增的主键)?
您可以对它使用数据库验证器。
它将显示一个带有来自外部表的值的选择框:(来自http://web2py.com/book/default/chapter/07?search=requires#Database-Validators):
考虑以下表格和要求:
db.define_table('person', Field('name', unique=True))
db.define_table('dog', Field('name'), Field('owner', db.person)
db.dog.owner.requires = IS_IN_DB(db, 'person.id', '%(name)s',
zero=T('choose one'))
它在狗 INSERT/UPDATE/DELETE 表单级别强制执行。它要求 dog.owner 是数据库 db 中 person.id 字段中的有效 id。由于这个验证器,dog.owner 字段被表示为一个保管箱。验证器的第三个参数是一个描述 Dropbox 中元素的字符串。在示例中,您希望查看人员 %(name)s 而不是人员 %(id)s。%(...)s 被每条记录括号中的字段值替换。
零选项的工作原理非常类似于IS_IN_SET
。
如果您希望验证字段,但不希望使用 Dropbox,则必须将验证器放入列表中。
db.dog.owner.requires = [IS_IN_DB(db, 'person.id', '%(name)s')]
验证器的第一个参数可以是数据库连接或 DAL 集,如IS_NOT_IN_DB
.
有时您需要下拉框(因此您不想使用上面的列表语法)但又想使用其他验证器。为此,IS_IN_DB 验证器采用额外的参数 _and 可以指向应用的其他验证器列表,如果验证值通过 IS_IN_DB 验证。例如,验证 db 中所有不在子集中的狗主人:
subset=db(db.person.id>100)
db.dog.owner.requires = IS_IN_DB(db, 'person.id', '%(name)s',
_and=IS_NOT_IN_DB(subset,'person.id'))
IS_IN_DB 验证器有一个可选属性 multiple=False。如果设置为 True 多个值可以存储在一个字段中。该字段应该是第 6 章中讨论的 list:reference 类型。那里讨论了一个明确的标记示例。多个引用在创建和更新表单中自动处理,但它们对 DAL 是透明的。我们强烈建议使用 jQuery 多选插件来呈现多个字段。