看官方的例子是這樣:
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`) )