laravel使用非自增id 模型查询取回id为0的解决方案

Laravel 数据库 Laravel 1100      收藏
laravel使用非自增id 模型查询取回id为0的解决方案

laravel 中 如果一个模型的id 为string等非自增类型时候 使用模型的find方法 会返会0

示例:

$info = User::find('1FC288E3E892AE23FE7C87B1BF97223C');
echo $info->id; //结果为0

原因查找:

通过var_dump($info)发现:

["attributes":protected]=>  array(16) {
    ["id"]=>
    string(4) "1FC288E3E892AE23FE7C87B1BF97223C"

也就是数据其实是读取出来了 只是->id取得时候 变成了0


查看Model的 getAttribute 方法,此方法指向了getAttributeValue

public function getAttributeValue($key)
{
    $value = $this->getAttributeFromArray($key);


    if ($this->hasGetMutator($key)) {
        return $this->mutateAttribute($key, $value);
    }


    if ($this->hasCast($key)) {
        return $this->castAttribute($key, $value); //这一行是导致数值改变的地方
    }


    if (in_array($key, $this->getDates()) && ! is_null($value)) {
        return $this->asDateTime($value);
    }

    return $value;
}

查看 castAttribute 如果 >getCastType(‘id’) 如果为int 则 (int)$value

protected function castAttribute($key, $value)
{
    if (is_null($value)) {
        return $value;
    }

    switch ($this->getCastType($key)) { 
        case 'int':
        case 'integer':
            return (int) $value; //这一行

查看 >getCastType

protected function getCastType($key)
{
    return trim(strtolower($this->getCasts()[$key]));
}

getCasts 最中改变值得代码:

public function getCasts()
{

    if ($this->getIncrementing()) { //如果Model了的$incrementing字段为True
        return array_merge([
            $this->getKeyName() => 'int', //返回id=>'int'
        ], $this->casts);
    }

    return $this->casts;
}

结论:

Model的$incrementing 默认为true 

当我们使用id为 非自增的时候 laravel 会把字符串转为int 所以输出了0

解决方案:

给模型生命的时候添加如下代码即可解决

public $incrementing=false;