【问题标题】:Generating JSON Query Result in Codeigniter在 Codeigniter 中生成 JSON 查询结果
【发布时间】:2018-08-29 19:08:44
【问题描述】:

所以我有一个名为 usermeta 的数据库表,并且有这样的表结构:

-----------------------------------------------------------
| ummeta_id | user_id | meta_key    | meta_value          |
-----------------------------------------------------------
| 1         | 1       | fullname    | John Doe            |
| 2         | 1       | birthplace  | New York            |
| 3         | 1       | birthdate   | 1990/01/01          |
| 4         | 1       | mobile      | 0812-3456-7890      |
| 5         | 1       | email       | john.doe@mail.com   |
| 6         | 2       | fullname    | Jon Wick            |
| 7         | 2       | birthplace  | Washington DC       |
| 8         | 2       | birthdate   | 1985/10/21          |
| 9         | 2       | mobile      | 0890-1234-5678      |
| 10        | 2       | email       | wickjohn@mail.com   |

我尝试使用 Codeigniter (v 3.1.9) 使用 Controller 和 Model 为该数据库中的所有数据生成 json 数据。

这是我的模型(模型名称:db_usermeta)

function userslist()
{
   $query = $this->db->select('*')
                     ->from('usermeta')
                     ->get();
   return $query->result();
}

这是我的控制器

public function userlist()
{
   header('Content-Type: application/json; charset=utf-8');
   $query = $this->db_usermeta->userslist();
   $json_data = array();
   foreach ($query as $key)
   {
      $json_data[$key->meta_key] = $key->meta_value;
   }
   echo json_encode($json_data);
}

当我使用浏览器打开使用web开发工具检查json数据时的结果是只显示最后一条记录,在这种情况下只显示来自user_id 2的数据,如下所示:

{
  "fullname":"John Wick",
  "birthplace":"Washinton DC",
  "birthdate":"1985/10/21",
  "mobile":"0890-1234-5678",
  "email":"wickjohn@mail.com"
}

我想要实现的是像这样显示所有嵌套的 json 数据:

"data": [
  {
    "fullname":"John Doe",
    "birthplace":"New York",
    "birthdate":"1990/01/01",
    "mobile":"0812-3456-7890",
    "email":"john.doe@mail.com"
  },
  {
    "fullname":"John Wick",
    "birthplace":"Washinton DC",
    "birthdate":"1985/10/21",
    "mobile":"0890-1234-5678",
    "email":"wickjohn@mail.com"
  }
]

我怎样才能做到这一点?我在控制器和模型上犯了错误吗?非常感谢您的帮助。

【问题讨论】:

    标签: php arrays json codeigniter codeigniter-3


    【解决方案1】:

    您的$key->meta_key 正在覆盖每条记录。这就是为什么只出现最后一条记录的原因。您实际上不需要循环获取 json 数据。

    public function userlist()
    {
       header('Content-Type: application/json; charset=utf-8');
       $query = $this->db_usermeta->userslist();
       $json_data = array(array());
       $user_id_map = array();
       $index = 0;
       foreach ($query as $key)
       {
            if(!isset($user_id_map[$key->user_id])){
                $user_id_map[$key->user_id] = $index++;
            }
            $currentIndex = $user_id_map[$key->user_id];
            $json_data[$currentIndex][$key->meta_key] = $key->meta_value;
       }
       echo json_encode($json_data);
    }
    

    只需将您的 controller 代码更改为此,这将返回 json 数据。

    【讨论】:

    • 我已经尝试了你的建议。但结果并不如我所料。 JSON 数据分别基于 umeta_id 显示。
    • @SigitDRedHat 尝试编辑后的答案,如果有帮助,请告诉我。
    • 哇!先生非常感谢您。你的代码真的很好用,真的帮助了我......
    【解决方案2】:

    由于两条记录的元键 fullname 相同,因此您需要将键名称更改为唯一的名称

    foreach ($query as $key)
       {
          $json_data[$key->meta_key] = $key->meta_value;
       }
    

    $json_data[$key->meta_key] 更改为$json_data[$key->meta_key.$key->user_id] 或者干脆改成$json_data[$key->ummeta_id]

    【讨论】:

      猜你喜欢
      • 2019-07-25
      • 2021-07-08
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多