时间:2021-05-18
问题
laravel5.2 中 如果一个模型的id 为string等非自增类型时候 使用模型的find方法 会返会0
样例代码:
$a=Model::find('blcu'); echo $a->id; //结果为0原因查找
通过var_dump(a)发现a)发现a
["attributes":protected]=> array(16) { ["id"]=> string(4) "blcu"也就是数据其实是读取出来了 只是->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; 即可解决
以上这篇解决laravel id非自增 模型取回为0 的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
区别:1、主键,Oracle不可以实现自增,mysql可以实现自增。oracle新建序列,SEQ_USER_Id.nextval2、索引:mysql索引从0开始
在MySQL中用很多类型的自增ID,每个自增ID都设置了初始值。一般情况下初始值都是从0开始,然后按照一定的步长增加(一般是自增1)。一般情况下,我们都是用in
在mysql中很多朋友都认为字段为AUTO_INCREMENT类型自增ID值是无法修改,其实这样理解是错误的,下面介绍mysql自增ID的起始值修改与设置方法。
在mysql中,实现id自增的方式是依靠加一个auto_increment标志,而在pgsql中,id自增是通过序列SEQUENCE。创建表时设置自增序列为:C
在设计API时,出于安全性等因素考虑,有时需要放弃使用自增ID,使ID非连续且不可猜测。通常可以使用Hashid,UUID,雪花ID等来实现。在最近的一个项目中