0

我正在使用我在本地安装并通过 pgAdmin 访问的musicbrainz.org postgresql 数据库。

该数据库是音乐艺术家和相关标准的列表。是架构。

可以列出艺术家可能拥有的各种关系。例如,这里是指向麦当娜的关系的链接,其中包括指向麦当娜的维基百科页面和她的推特句柄等的链接。

如何创建一个 SQL 查询来输出给定艺术家的所有关系?我努力了:

SELECT 
  url.url, 
  artist.name
FROM 
  musicbrainz.artist, 
  musicbrainz.url, 
  musicbrainz.link
WHERE 
  url.id = artist.id
ORDER BY
  url.url ASC;

但是,这些链接与正确的艺术家不相关。我用错了钥匙吗?

4

1 回答 1

2

我查看了模型,但您缺少 l_artist_url 表:

SELECT url.url,
       artist.name
FROM artist
  JOIN l_artist_url ON artist.id = l_artist_url.entity0
  JOIN url ON url.id = l_artist_url.entity1
WHERE artist.name = '...'
ORDER BY url.url ASC

要获取与艺术家相关的事件,您可以使用以下内容:

SELECT event.name, 
       event_type.name
FROM artist
  JOIN l_artist_event ON artist.id = l_artist_event.entity0 
  JOIN event ON event.id = l_artist_event.entity1 
  join event_type ON event_type.id = event.type 
WHERE artist.name = '...'
于 2015-01-10T23:06:00.197 回答