mysql左连接和内连接3表

时间:2016-05-05 21:40:35

标签: mysql left-join inner-join

我有3个表:oc_artists,oc_songs,oc_songs_tags

我可以使用以下代码选择2个表:

SELECT * FROM `oc_songs` LEFT JOIN oc_songs_tags ON oc_songs.song_id=oc_songs_tags.song_id 
WHERE oc_songs_tags.song_tag IS NULL

现在我需要从oc_artists中选择数据......我试过这个问题的答案: MySQL LEFT JOIN 3 tables

这是我的代码:

SELECT * FROM oc_songs
LEFT JOIN oc_artists
    INNER JOIN oc_songs_tags
    ON oc_songs.song_artist_id = oc_artists.artist_id
ON oc_songs_tags.song_id = oc_songs.song_id

但我收到此错误

8 errors were found during analysis.

Unrecognized keyword. (near "ON" at position 131)
Unexpected token. (near "oc_songs_tags" at position 134)
Unexpected token. (near "." at position 147)
Unexpected token. (near "song_id" at position 148)
Unexpected token. (near "=" at position 156)
Unexpected token. (near "oc_songs" at position 158)
Unexpected token. (near "." at position 166)
Unexpected token. (near "song_id" at position 167)

3 个答案:

答案 0 :(得分:1)

ON子句的错误位置

SELECT * FROM oc_songs
LEFT JOIN oc_artists ON oc_songs.song_artist_id = oc_artists.artist_id
INNER JOIN oc_songs_tags  ON oc_songs_tags.song_id = oc_songs.song_id

答案 1 :(得分:1)

你的语法错了。加入语法是:

[JOIN TYPE] JOIN [TABLE B] ON [TABLE A].[COLUMN] = [TABLE B].[COLUMN]

这意味着:

SELECT * FROM oc_songs
 LEFT JOIN oc_artists ON oc_songs.song_artist_id = oc_artists.artist_id
 INNER JOIN oc_songs_tags ON oc_songs.song_id = oc_songs_tags.song_id

理解JOINS的简单方法是它们始终是FROM中列出的主表和您正在JOINING的表之间的连接。因此,请将JOIN子句视为连词列表。

因此,要将TableA与TableB,TableC和TableD连接起来,您可能会遇到类似的事情:

SELECT * FROM TableA
  JOIN TableB on TableA.tableb_id = TableB.id  -- this is first join
  JOIN TableC on TableA.tablec_id = TableC.id  -- this is second join
  JOIN TableD on TableA.tabled_id = TableD.id  -- this is third join

答案 2 :(得分:1)

示例表:

DROP TABLE IF EXISTS `oc_songs` ;
DROP TABLE IF EXISTS `oc_songs_tags` ;
DROP TABLE IF EXISTS `oc_artists` ;

CREATE TABLE `oc_songs` (
  `song_id` int(10) unsigned NOT NULL auto_increment,
  `song_name` varchar(255) NOT NULL,
  `song_artist_id`  int(10),
  PRIMARY KEY  (`song_id`),
  foreign key (`song_artist_id`) references oc_artists(`artist_id`)
) ENGINE=MyISAM AUTO_INCREMENT=1 DEFAULT CHARSET=latin1;

CREATE TABLE `oc_songs_tags` (
  `song_tag_id` int(10) unsigned NOT NULL auto_increment,
  `song_tag` varchar(255) NOT NULL,
  `song_id` int(10),
  PRIMARY KEY  (`song_tag_id`),
  foreign key (`song_id`) references oc_songs(`song_id`)
) ENGINE=MyISAM AUTO_INCREMENT=1 DEFAULT CHARSET=latin1;

CREATE TABLE `oc_artists` (
  `artist_id` int(10) unsigned NOT NULL auto_increment,
  `artist_age` int(4),
  PRIMARY KEY  (`artist_id`)

) ENGINE=MyISAM AUTO_INCREMENT=1 DEFAULT CHARSET=latin1;

右选:

SELECT * FROM oc_songs
 LEFT JOIN oc_artists ON 
    oc_songs.song_artist_id = oc_artists.artist_id
 INNER JOIN oc_songs_tags ON 
    oc_songs.song_id = oc_songs_tags.song_id;