我在使用LaravelBook/Ardent时遇到了问题。我的逻辑是使用以下代码在唯一验证中排除软删除的行:
public static $rules = array(
'name' => 'required|unique:paper_colors,name,deleted_at,NULL',
'description' => 'required|between:2,255',
'code' => 'required'
);但是,当我运行updateUniques时,我仍然得到The name has already been taken.和这个sql:
select count(*) as aggregate from `paper_colors` where `name` = '4/0' and `id` <> '2'我预计sql将是:
select count(*) as aggregate from `paper_colors` where `name` = '4/0' and `id` <> '2' and `deleted_at` is null有人能帮我解决这个问题吗。我昨晚差点被困在这上面了。还是想不出怎么处理这件事。
发布于 2014-01-28 01:32:29
我发现阿登特放弃了Laravel验证功能:加入附加Where条款
因此,我克服这个错误的解决方案是在LaravelBook\Ardent\Ardent@buildUniqueExclusionRules下添加额外的代码:799,但是我没有这样做,因为我依赖于它们将来的任何更新。所以我只创建一个类来扩展LaravelBook\Ardent\Ardent并复制buildUniqueExclusionRules并修改它。
if (count($params)>2)
{
$c = count($uniqueRules);
for ($i=1; $i < count($params); $i++, $c++) {
$uniqueRules = array_add($uniqueRules, $c, $params[$i]);
}
}https://stackoverflow.com/questions/21394824
复制相似问题