ВЫБОР SQL несколько ВНУТРЕННИХ ОБЪЕДИНЕНИЙ

его база данных Access..

у меня есть таблица Library, где Autnm Topic Size Cover Lang является внешними ключами

каждая запись является на самом деле книгой, которая имеет ее свойства, такие как автор и материал. я не совсем уверен, что даже использую корректное СОЕДИНЕНИЕ.. довольно новый со "сложным" SQL :)

SELECT Library.Bknm_Hebrew, Library.Bknm_English, Library.Bknm_Russian, Library.Note,
       Library.ISBN, Library.Pages, Library.PUSD, Author.ID AS [AuthorID],
       Author.Author_hebrew AS [AuthorHebrew],
       Author.Author_English AS [AuthorEnglish],
       Author.Author_Russian AS [AuthorRussian], Topic.ID AS [TopicID],
       Topic.Topic_Hebrew AS [TopicHebrew], Topic.Topic_English AS [TopicEnglish],
       Topic.Topic_Russian AS [TopicRussian], Size.Size AS [Size],
       Cover.ID AS [CoverID], Cover.Cvrtyp_Hebrew AS [CoverHebrew],
       Cover.Cvrtyp_English AS [CoverEnglish], Cover.Cvrtyp_Russian AS [CoverRussian],
       Lang.ID AS [LangID], Lang.Lang_Hebrew AS [LangHebrew],
       Lang.Lang_English AS [LangEnglish],

FROM Library INNER JOIN Author ON Library.Autnm = Author.ID
                 INNER JOIN Topic ON Library.Topic = Topic.ID
                 INNER JOIN Size ON Library.Size = Size.ID
                 INNER JOIN Cover ON Library.Cover = Cover.ID
                 INNER JOIN Lang ON Library.Lang = Lang.ID
WHERE (TopicID=13 AND LangID=1) ORDER BY LangID ASC 

Править: После вставки круглых скобок @Guffa предложенный, я получил новую ошибку:

Too few parameters. Expected 3.

5
задан Christian Ammer 10 June 2013 в 10:28
поделиться

2 ответа

В Access вам нужны скобки, если у вас более одного соединения. Кроме того, как указал Ивар, у вас есть дополнительная запятая после последнего элемента в списке полей.

select
  Library.Bknm_Hebrew, Library.Bknm_English, Library.Bknm_Russian, Library.Note,
  Library.ISBN, Library.Pages, Library.PUSD, Author.ID as [AuthorID],
  Author.Author_hebrew as [AuthorHebrew], Author.Author_English as [AuthorEnglish],
  Author.Author_Russian as [AuthorRussian], Topic.ID as [TopicID],
  Topic.Topic_Hebrew as [TopicHebrew],  Topic.Topic_English as [TopicEnglish],
  Topic.Topic_Russian as [TopicRussian], Size.Size as [Size], Cover.ID as [CoverID],
  Cover.Cvrtyp_Hebrew as [CoverHebrew], Cover.Cvrtyp_English as [CoverEnglish],
  Cover.Cvrtyp_Russian as [CoverRussian], Lang.ID as [LangID],
  Lang.Lang_Hebrew as [LangHebrew], Lang.Lang_English as [LangEnglish]  
from
  (((((Library
  inner join Author on Library.Autnm = Author.ID)
  inner join Topic on Library.Topic = Topic.ID)
  inner join Size on Library.Size  = Size.ID)
  inner join Cover on Library.Cover = Cover.ID)
  inner join Lang on Library.Lang  = Lang.ID)

Редактировать:

Сообщение об ошибке «Слишком мало параметров». означает, что вы определили параметры в запросе, который не отправляется при выполнении. Поскольку вы не используете какие-либо параметры в запросе, это означает, что вы неправильно написали некоторые имена в запросе, поэтому вместо этого он считает, что они являются параметрами.

15
ответ дан 18 December 2019 в 09:47
поделиться

Я не слишком знаком с Access и поэтому не уверен, принимает ли он это, но я бы начал с удаления последней запятой из списка выбора.

Lang.Lang_English AS [LangEnglish], => Lang.Lang_English AS [LangEnglish]
2
ответ дан 18 December 2019 в 09:47
поделиться
Другие вопросы по тегам:

Похожие вопросы: