PHP使用PDO库查询数据库除了NULL所有字段都返回的是字符串

返回的数组值都是字符串

[
    "id" => "4231",
    "status" => "2"
]

这个问题让我很困惑,因为这样的数据转换成json后全部都变成了字符串,虽然理论上说,数据全字符串是比较安全的,但是对接强类型语言的时候会很难搞。

有什么解决方案吗?_(:3」∠)_

阅读 5k
2 个回答

设置一下PDO的属性

$pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);

就可以了

无解。除非自己强制类型。输出的时候自己格式化。

function format($arr) {
    $arr['id'] = (int)$arr['id'];
    $arr['status'] = (int)$arr['status'];
    return json_encode($arr);
}
echo format(['id'=>'111','status'=>'2']);
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题