dongshushi5579 2019-02-15 03:48
浏览 505
已采纳

使用Joins在laravel视图中显示Json数据

I'm trying to retrieve data from database to laravel blade view with join associate table.

in my case I have two tables called interesting_courses and courses. here some student can have many interesting courses. Therefore courses_id stored as json array in database as follows.

["1","11","15","16"] 

but I need to join the courses table to get the associate course name as follows.

["Hospitality","Business Management","Auto Mobile","Health Care"]

Below is my controller

$intresting_courses = DB::table('intresting_courses')
                            ->join('courses','courses.id','=','intresting_courses.courses_id')
                            ->where('intresting_courses.youth_id',$id)
                            ->first();

How can I join the tables.

  • 写回答

1条回答 默认 最新

  • dqyat62284 2019-02-15 04:28
    关注

    There is no way you can join it in query natively.

    The solution is to write two queries

    select * from intresting_courses where youth_id = ? limit 1
    
    select * from courses where id in (1, 2, 3, 4, 5, ...)
    

    that way you can get courses that student intresting.

    Here the laravel code for thoses queries.

    $intresting_courses = DB::table('intresting_courses')
                            ->where('intresting_courses.youth_id', $id)
                            ->first();
    
    $courses = DB::table('courses')
                 ->whereIn('id', json_decode($intresting_courses->courses_id))
                 ->get();
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 服务端控制goose报文控制块的发布问题
  • ¥15 学习指导与未来导向啊
  • ¥15 求多普勒频移瞬时表达式
  • ¥15 如果要做一个老年人平板有哪些需求
  • ¥15 k8s生产配置推荐配置及部署方案
  • ¥15 matlab提取运动物体的坐标
  • ¥15 人大金仓下载,有人知道怎么解决吗
  • ¥15 一个小问题,本人刚入门,哪位可以help
  • ¥30 python安卓开发
  • ¥15 使用R语言GD包一直不出结果