我的User
表包含zerofill主id
:
CREATE TABLE `user` (
`id` int(5) unsigned zerofill NOT NULL AUTO_INCREMENT,
`email` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB
我的User
模型如下:
class User extends ActiveRecord implements IdentityInterface
{
public static function tableName()
{
return '{{%user}}';
}
public static function findIdentity($id)
{
$identity = static::findOne(['id' => (int)$id]);
var_dump($identity); //zeros are lost here
exit;
}
public static function findIdentityByAccessToken($token, $type = null)
{
throw new NotSupportedException('"findIdentityByAccessToken" is not implemented.');
}
public function getId()
{
return $this->getPrimaryKey();
}
public function getAuthKey()
{
return $this->auth_key;
}
public function validateAuthKey($authKey)
{
return $this->getAuthKey() === $authKey;
}
}
Active Record会将id
投射到int
,所以我得到1
00001
; 2
等00002
,但我想保留零并将id
视为string
。
在x32系统上一切正常,但我们转移到了x64。如何强制Active Record将id
视为string
?
答案 0 :(得分:0)
Yii从查询结果填充数据中的对象时,会使用方法
\yii\db\ColumnSchema::typecast
从数据库中检索后,Means根据[[phpType]]转换输入值。
如果您的ID是整数,那么将使用下一条规则
case 'integer':
return (int) $value;
这就是为什么 00001 转换为 1
的原因我找到了下一个解决方案,不是最好的,但是无论如何
每次尝试获取ID时,都会调用下一个函数
public function getId()
{
return str_pad($this->id, 5, '0', STR_PAD_LEFT);
}
覆盖afterFind和afterSave方法
public function refreshUserId()
{
$this->id = str_pad($this->id, 5, '0', STR_PAD_LEFT);
}
public function afterFind()
{
parent::afterFind();
$this->refreshUserId();
}
public function afterSave($insert, $changedAttributes)
{
parent::afterSave($insert, $changedAttributes);
$this->refreshUserId();
}