首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >mysql中的Join 3表

mysql中的Join 3表
EN

Stack Overflow用户
提问于 2016-03-01 12:26:42
回答 2查看 81关注 0票数 2

表1名称: nfc_film

列名= id,film_id,标题,描述

表2名称: nfc_film_actor

列名= id,actor_id,film_id

表3名称: nfc_actor

列名= actor_id,first_name,last_name

问题:,我怎样才能把这3张桌子连在一起?

我想从表first_name和last_name中获得值nfc_actor,但是我的查询不工作。

我的问题是:

代码语言:javascript
复制
SELECT * 
FROM nfc_film 
INNER JOIN nfc_film_actor ON 
    nfc_film_actor.film_id = nfc_film.film_id 
INNER JOIN nfc_actor ON 
    nfc_actor.actor_id = nfc_film_actor.actor_id 
WHERE nfc_film.film_id = :filmid 
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-03-01 13:13:57

您不能在查询中使用*选择器,因为id、actor_id和film_id存在于多个表中,这肯定是错误的。您应该参考每个字段的特定名称。

如果您检查您的网络服务器error.log,您可以看到这一点。

也许你是说:

代码语言:javascript
复制
SELECT first_name, last_name FROM nfc_film 
INNER JOIN nfc_film_actor
  ON nfc_film_actor.film_id = nfc_film.film_id 
INNER JOIN nfc_actor
  ON nfc_actor.actor_id = nfc_film_actor.actor_id 
WHERE nfc_film.film_id = nfc_film_actor.film_id
票数 0
EN

Stack Overflow用户

发布于 2016-03-01 13:31:52

使用这个

代码语言:javascript
复制
 SELECT  nfc_actor.first_name,nfc_actor.last_name,
FROM nfc_film 
INNER JOIN nfc_film_actor 
ON nfc_film_actor.film_id = nfc_film.film_id 
INNER JOIN nfc_actor 
ON nfc_actor.actor_id = nfc_film_actor.actor_id 
WHERE nfc_film.film_id = 'some_id'; 

在“some_id”一词中给出胶片的id

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35722937

复制
相关文章

相似问题

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