首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何获得带有外键的表的倍数值?

如何获得带有外键的表的倍数值?
EN

Stack Overflow用户
提问于 2018-10-17 10:38:36
回答 3查看 22关注 0票数 0

如何让一个老师的所有学生,每个学生只有一个老师,每个老师有很多学生,我正在使用这个SQL请求,它只给每个老师带来一个学生,你能帮我吗?

代码语言:javascript
复制
   $data = '';
          $sth = Model::connect()->prepare('SELECT a.name ,
          b.nameTeacher 
          FROM table1 b , table2 a
         WHERE a.id_teacher = b.id GROUP BY b.id');
               $sth->execute();
                 $data = $sth->fetchAll();


        return $data;

表1

教师: Id nameTeacher

表2

学生: Id 名字 Id_teacher

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2018-10-17 10:39:55

删除GROUP BY并学习使用正确、显式、标准的 JOIN语法:

代码语言:javascript
复制
SELECT a.name, b.nameTeacher 
FROM table1 b JOIN
     table2 a
     ON a.id_teacher = b.id ;
票数 0
EN

Stack Overflow用户

发布于 2018-10-17 10:48:14

这将起作用:

代码语言:javascript
复制
select a.name,b.nameTeacher from students a ,teacher b
where a.Id_teacher=b.Id 
票数 0
EN

Stack Overflow用户

发布于 2018-10-17 11:11:27

代码语言:javascript
复制
SELECT b.nameTeacher, count(a.name) as numberOfStudents
      FROM table1 b , table2 a
     WHERE a.id_teacher = b.id GROUP BY b.id

或者:

代码语言:javascript
复制
 SELECT a.Id, a.name
      FROM table1 b , table2 a
     WHERE a.id_teacher = b.id and (b.id = [input ID] or b.nameTeacher = [input name]
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52852921

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档