Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: SQL в Access  (Прочитано 7513 раз)
0 Пользователей и 4 Гостей смотрят эту тему.
Domra
Участник

ru
Offline Offline
Пол: Женский

« : 18-05-2015 14:45 » 

Подскажите, пожалуйста, как выбрать все строки из таблицы через ее псевдоним.

Вот такая конструкция не катит (не воспринимается .* после С):

SELECT C.*, O.order_num, O.order_date, OI.prod_id,  OI.quantity, OI.item_price
FROM Customers AS C, Orders AS O, OrderItems AS OI 
WHERE C.cust_id = O.cust_id
AND OI.order_num = О.order_num
AND prod_id = 'RGAN01';

почему-то Здесь была моя ладья...

Добавлено через 12 минут и 45 секунд:
а, похоже псеводнимы вообще в Access не воспринимаются до тех пор, пока они не определены.
« Последнее редактирование: 18-05-2015 14:57 от Domra » Записан
RXL
Технический
Администратор

Offline Offline
Пол: Мужской

WWW
« Ответ #1 : 18-05-2015 21:09 » 

https://support.office.com/en-za/article/Introduction-to-Access-SQL-d5f21d10-cd73-4507-925e-bb26e377fe7e#bm7

Возможно у него какой-то конфликт синтаксиса. Попробуй обернуть идентификаторы. И почитай по ссылке: есть подозрение, что нужно писать через INNER JOIN
Записан

... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
Domra
Участник

ru
Offline Offline
Пол: Женский

« Ответ #2 : 01-06-2015 08:26 » 

А, точно, спасибо большое! Жжешь
Записан
HandKot
Молодой специалист

ru
Offline Offline

« Ответ #3 : 13-07-2015 10:42 » 

Подскажите, пожалуйста, как выбрать все строки из таблицы через ее псевдоним.

Вот такая конструкция не катит (не воспринимается .* после С):

SELECT C.*, O.order_num, O.order_date, OI.prod_id,  OI.quantity, OI.item_price
FROM Customers AS C, Orders AS O, OrderItems AS OI 
WHERE C.cust_id = O.cust_id
AND OI.order_num = О.order_num
AND prod_id = 'RGAN01';

почему-то Здесь была моя ладья...

Добавлено через 12 минут и 45 секунд:
а, похоже псеводнимы вообще в Access не воспринимаются до тех пор, пока они не определены.
Синтаксис вполне рабочий. Думаю, что проблема в том, что у Вас в запросе поля вывода имеют одно и тоже имя: в таблице Customers и Orders есть поле  order_num , которое Вы выводите и из одной таблицы и из другой. Также, возможно есть и другие поля
если переписать так, что проблем быть не должно

Код:
SELECT C.*, O.order_num AS [order_num from Orders], O.order_date, OI.prod_id,  OI.quantity, OI.item_price 
FROM Customers AS C, Orders AS O, OrderItems AS OI 
WHERE C.cust_id = O.cust_id
AND OI.order_num = О.order_num
AND prod_id = 'RGAN01';
или же из ORDERS это поле не выводить
Записан

I Have Nine Lives You Have One Only
THINK!
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines