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

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

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

protected $rule = [
    'catename' => 'unique:cate|require|length:4,25'
];
protected $message = [
    'catename.require' => '請(qǐng)?zhí)顚?xiě)欄目名稱',
    'catename.unique' => '欄目已存在',
    'catename.length' => '長(zhǎng)度不在3-5個(gè)字符',
];

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

public function edit($data)
{

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

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

回答
編輯回答
囍槑

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

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

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

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

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

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

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

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

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


自己貼過(guò)來(lái)吧:

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

$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' => '分類名稱必須填寫(xiě)',
    'name.unique' => '分類名稱已存在',
    'sort.number' => '排序必須填寫(xiě)整數(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