鍍金池/ 問答/PHP  HTML/ ThinkPHP5.0數(shù)據(jù)更新驗證唯一性怎么驗證。

ThinkPHP5.0數(shù)據(jù)更新驗證唯一性怎么驗證。

簡單的小項目在自定義驗證字段時,數(shù)據(jù)插入數(shù)據(jù)庫可以正常驗證!想要在數(shù)據(jù)更新時也使用本套驗證方法,就是一個字段比如catename字段,需要驗證是否存在,然后在數(shù)據(jù)庫中是否是唯一一個.ThinkPHP5
以下自定義驗證是代碼:(很簡單的)
class Admin extends validate
{

protected $rule = [
    'catename' => 'unique:cate|require|length:4,25'
];
protected $message = [
    'catename.require' => '請?zhí)顚憴谀棵Q',
    'catename.unique' => '欄目已存在',
    'catename.length' => '長度不在3-5個字符',
];

}
然后數(shù)據(jù)更新代碼:model層
//欄目修改

public function edit($data)
{

    $validate = new Admin();
    if ($validate->check($data)) {//驗證數(shù)據(jù)是否正確
        $num = Cate::isUpdate(true)->save($data);
        return $num;
    } else {
        return $validate->getError();
    }
}

這里出現(xiàn)了一個問題:就是當(dāng)我不做修改的時候數(shù)據(jù)是肯定修改失敗的!因為沒有做任何修改返回沒有影響的行數(shù)!但是if判斷那邊他是執(zhí)行的!也是執(zhí)行成功的!就好比我修改的數(shù)據(jù)是"菜單欄",我不修改原樣放進去它驗證成功!我依稀記得更新操作都是先刪除原始數(shù)據(jù)重新插入數(shù)據(jù)這樣一個流程,那我判斷唯一性就失效了!但是更新時我又要怎么判斷他是否唯一呢!小白還請各位給點意見!

回答
編輯回答
囍槑

你的描述我看的稀里糊涂。。。。你想辦法理一下思路,簡便一下發(fā)言,這樣我們才好幫你找問題。。

2018年4月30日 16:55
編輯回答
墨染殤

感謝評論區(qū)的回答

2017年4月2日 10:04
編輯回答
雨萌萌

我的是tp5.0.19用上面的方法不行,但是看了這篇文章:https://www.cnblogs.com/PHPak...;
在編輯頁面form表單中添加一個隱藏域:<input type="hidden" name="表中id字段名" value="get方式傳過來的id值">(千萬注意name要和主鍵同名),然后定義好驗證器類中的相關(guān)規(guī)則,此時不需再要定義驗證場景了,添加編輯都用同一規(guī)則:
class Admin extends Validate
{
protected $rule = [
[
'account', 'require|length:3,15|checkChanese:|checkSpecial:|unique:admin,admin_account', '賬號必須填寫|賬號長度在3~15個字符之間|賬號中不能含有中文|賬號中不能含有特殊字符|該賬號已存在,請重新添加']
]
}
模型中驗證:
//執(zhí)行驗證
$validate = validate('Admin');
if ($validate->check($data)) {//驗證通過......}else{//驗證失敗......}
親測可用。。。希望可以幫到大家

2018年5月23日 20:51
編輯回答
枕邊人

我覺得數(shù)據(jù)庫表字段設(shè)置成唯一就可以了,如果存在,就直接插入失敗。如果想高級的話就根據(jù)用戶輸入內(nèi)容先查詢下,存在了返回一個友好提示。這應(yīng)該難不到你。

2017年2月25日 00:09
編輯回答
敢試

問題應(yīng)該就是更新時的唯一性判定是要排除自身的。
我記得看過tp5驗證這塊的代碼,要是單獨在valide驗證器類里是實現(xiàn)不了的,因為這個類里沒找到怎么獲取傳遞過來的參數(shù)。但是在controller中可以實現(xiàn),但文檔中根本沒有細說,我在他們官方文檔下面的評論中有具體的怎么實現(xiàn)的代碼,可以參考下,或者幫忙貼過來。


自己貼過來吧:

文檔太簡陋了,還要看源碼才行,'name' => 'unique:user,status=1&account='.$data['account'],這種的只能放在controller中,自己來定義rulemessage,在單獨的validate類中無法將相關(guān)的值傳遞過去。
規(guī)則是:unique:【模型類名(或表名)】,【要驗證的字段(或者包含=號或者包含^號,但是必須把本身的條件加入,別以為前面有name了就不把name本身加進去了)】,【要排除的字段】,【主鍵(可不填)】
示例:

$id = $this->request->post('id');
$shopId = session('shop_id');
$name = $this->request->post('name');
$sort = $this->request->post('sort', 0, 'intval');
$postData = [
    'name' => $name,
    'sort' => $sort
];
$rule = [
    'name' => 'require|unique:ArticleCategory,shop_id=' . $shopId . '&name=' . $name,//名稱
    'sort' => 'number'
];
$message = [
    'name.require' => '分類名稱必須填寫',
    'name.unique' => '分類名稱已存在',
    'sort.number' => '排序必須填寫整數(shù)',
];
$validate = new Validate($rule, $message);
if (!empty($id)) {
    $validate->scene('edit',
        [
            'sort',
            'name' => 'require|unique:ArticleCategory,shop_id=' . $shopId . '&name=' . $name . ',' . $id
        ]);
    $validateRes = $validate->scene('edit')->check($postData);
} else {
    $validate->scene('add', ['sort', 'name']);
    $validateRes = $validate->scene('add')->check($postData);
}
if (true !== $validateRes) {
    $data['msg'] = $validate->getError();
    return json($data);
}
2018年3月6日 19:47