Google App Maker 如何应用自定义数据验证
Google App Maker how to apply custom data validation
App Maker 有默认验证和正则表达式验证,一旦发生错误就会突出显示字段。
我们需要进行自定义验证以检查模型中的重复记录。是否有任何检查验证的功能或我们是否需要执行任何脚本?
避免数据重复的最佳方法是使用 Cloud SQL 对您的表实施 'unique' 约束。
如果您不想使用 Cloud SQL 并想使用 Drive Tables,您可以使用锁、查询和模型事件手动模拟唯一约束:
// onCreate model event (actually it is onBeforeCreate)
// this events accepts about-to-create record as parameter
var lock = LockService.getScriptLock();
lock.waitLock(5000);
var query = app.models.MyModel.newQuery();
query.filters.SomeField._equals = record.SomeField;
var records = query.run();
if (records.length > 0) {
throw new Error('Record with SomeField value equal to ' + record.SomeField +
' already exists.');
}
lock.releaseLock();
你需要lock
在这里防止其他线程同时创建违反你的唯一约束的记录。
然后你可以在createItem
函数回调中处理UI的错误:
// create button onClick handler
widget.datasource.createItem({
success: function(record) {
// TODO
},
failure: function(error) {
// TODO
}
});
App Maker 有默认验证和正则表达式验证,一旦发生错误就会突出显示字段。
我们需要进行自定义验证以检查模型中的重复记录。是否有任何检查验证的功能或我们是否需要执行任何脚本?
避免数据重复的最佳方法是使用 Cloud SQL 对您的表实施 'unique' 约束。
如果您不想使用 Cloud SQL 并想使用 Drive Tables,您可以使用锁、查询和模型事件手动模拟唯一约束:
// onCreate model event (actually it is onBeforeCreate)
// this events accepts about-to-create record as parameter
var lock = LockService.getScriptLock();
lock.waitLock(5000);
var query = app.models.MyModel.newQuery();
query.filters.SomeField._equals = record.SomeField;
var records = query.run();
if (records.length > 0) {
throw new Error('Record with SomeField value equal to ' + record.SomeField +
' already exists.');
}
lock.releaseLock();
你需要lock
在这里防止其他线程同时创建违反你的唯一约束的记录。
然后你可以在createItem
函数回调中处理UI的错误:
// create button onClick handler
widget.datasource.createItem({
success: function(record) {
// TODO
},
failure: function(error) {
// TODO
}
});