看官方的例子是这样:
https://docs.phalconphp.com/zh/latest/reference/model-validation.html ,目前官方已经改过来了php
$validator->validate( "name", new Uniqueness() );
而后我也这样写,直接返回502错误,通过我一番摸索,正确的写法将$validator->validate
换成$validator->add
:html
$validator->add( "name", new Uniqueness() );
记得后面别忘记加 return $this->validate($validator);
被官方例子坑死了!
我在官方论坛提的问题:
https://forum.phalconphp.com/discussion/13847/model-validate-return-503-bad-gatewaymysql
若是你设置了getter一个字段的时候,恰好Uniqueness验证的也是这个字段,会致使Uniqueness验证失效(他会拿getter后的值来对比),解决方法是,经过getter返回一个新字段,而不是原字段。sql
protected $titlenew; public function getTitlenew() { return $this->title.'...'; }
另外学习到设置联合惟一约束的方法,好比不能插入用户名和邮件都同样的数据ide
//s和surl为联合惟一约束 $validator->add( ['s', 'surl'], new Uniqueness([ 'message' => '数据已存在' ]) );
注意:mysql中能够设置联合惟一约束,但必须结合模型验证中的Uniqueness使用,不然phalcon插入的时候失败会返回503错误学习
CREATE TABLE `d_spider` ( ... UNIQUE KEY `s_surl` (`s`,`surl`) )