Форум программистов, компьютерный форум, киберфорум
MySQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.79/34: Рейтинг темы: голосов - 34, средняя оценка - 4.79
 Аватар для gitarillo
755 / 554 / 48
Регистрация: 17.06.2010
Сообщений: 1,041
Записей в блоге: 1

Использование вычисляемого столбца в конструкции SELECT

06.06.2012, 17:27. Показов 6790. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
День добрый.
Никак не могу понять следующее. Вот запрос

MySQL
1
2
3
4
5
6
SELECT `№ вход` , `Отдел` , 
(SELECT `Дата изменения`FROM `История создания 2012`WHERE 
(`Заявка` = `Реестр 2012`.`№ вход`)
ORDER BY `Дата изменения` LIMIT 1 ) AS `Дата создания` , 
(TIMESTAMPDIFF(DAY , `Дата создания`, NOW() )) AS `Просрочка` `Реестр 2012`
HAVING(`Дата КП` IS NULL AND `Просрочка`>1)
Ругается у меня на `Дата создания` в функции TIMESTAMPDIFF. Как мне использовать вычисляемое значение в функции, которая возвращает новые значения для нового столбца Просрочка?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.06.2012, 17:27
Ответы с готовыми решениями:

Как оформить условие на попадание в диапазон в конструкции Select Case ... End Select?
Народ, подскажите please, правильна ли конструкция следующего кода: Sub пример() pp2 = Str(InputBox("введите число")) ...

Вложенные конструкции SELECT(SELECT)
Допустим имеется: Me.Graph1.RowSource='SELECT Query1.ID, Query1.Data, Query2.AvgOfData FROM Query1, Query2;', где...

Создание вычисляемого столбца
Oracle 11g Пытаюсь создать вычисляемый столбец (заполняется по условию, но пока пытаюсь хоть что-нибудь вывести) ALTER TABLE...

6
Заблокирован
07.06.2012, 09:19
Второй FROM потерялся.
Хотел поэкспериментировать, но у меня phpMyAdmin таблицы типа `История создания 2012` создает и не показывает их.
Я правильно понимаю на выходе должна быть таблица с колонками `№ вход` , `Отдел` , `Дата создания` , `Просрочка`?
Что пишет, когда ругается?
Во вложенном запросе используется `Реестр 2012`.`№ вход`. Может стоит во FROM `Реестр 2012` добавить или JOIN, чтоб связь была. Или как-то так.
1
 Аватар для gitarillo
755 / 554 / 48
Регистрация: 17.06.2010
Сообщений: 1,041
Записей в блоге: 1
07.06.2012, 09:29  [ТС]
Цитата Сообщение от Dzhej-Dzhej Посмотреть сообщение
Я правильно понимаю на выходе должна быть таблица с колонками `№ вход` , `Отдел` , `Дата создания` , `Просрочка`?
Да, все верно.

Цитата Сообщение от Dzhej-Dzhej Посмотреть сообщение
Во вложенном запросе используется `Реестр 2012`.`№ вход`. Может стоит во FROM `Реестр 2012` добавить или JOIN, чтоб связь была. Или как-то так.
Ну на самом деле связь есть, если убрать
MySQL
1
(TIMESTAMPDIFF(DAY , `Дата создания`, NOW() )) AS `Просрочка`
FROM на самом деле есть. зачем-то его здесь вырезал.
0
Заблокирован
07.06.2012, 10:52
Попробуйте как-то так.
SQL
1
2
3
4
5
6
7
SELECT `№ вход` , `Отдел` , 
`Дата создания` , 
(TIMESTAMPDIFF(DAY , `Дата создания`, NOW() )) AS `Просрочка` FROM `Реестр 2012`, 
(SELECT `Дата изменения` AS `Дата создания` FROM `История создания 2012`WHERE 
(`Заявка` = `Реестр 2012`.`№ вход`)
ORDER BY `Дата изменения` LIMIT 1 ) AS `Д`
HAVING(`Дата КП` IS NULL AND `Просрочка`>1)
Цитата Сообщение от Dzhej-Dzhej Посмотреть сообщение
Что пишет, когда ругается?
Если я правильно понял, ругалось на "область видимости"
0
2 / 2 / 1
Регистрация: 07.06.2012
Сообщений: 39
07.06.2012, 11:07
При указании ключевых слов следует точно соблюдать порядок, указанный выше. Например, выражение HAVING должно располагаться после всех выражений GROUP BY и перед всеми выражениями ORDER BY!!!
0
 Аватар для gitarillo
755 / 554 / 48
Регистрация: 17.06.2010
Сообщений: 1,041
Записей в блоге: 1
07.06.2012, 11:14  [ТС]
boyboy61, с HAVING все в порядке ведь. Проблема в том, что когда я в функции TIMESTAMPDIFF использую псевдоним `Дата создания` MySql говорит что это поле неизвестно.
0
1 / 1 / 6
Регистрация: 23.09.2014
Сообщений: 176
08.10.2014, 11:55
млин объясните нубу.
вот этот запрос намертво ложит емс

SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
   SELECT
            FIRST 1 D + T            
            FROM PROTOKOL
             LEFT OUTER JOIN CARGO CARGO1 ON (PROTOKOL.FK_CARGO = CARGO1.ID_CARGO)
            WHERE 
             (    D +  T >  
           (
            SELECT
            FIRST 1 D + T  
            FROM PROTOKOL
            LEFT OUTER JOIN CARGO CARGO1 ON (PROTOKOL.FK_CARGO = CARGO1.ID_CARGO)
            WHERE 
          (D +  T >  '07.10.2014 8:00:00' AND D +  T <  '07.10.2014 20:00:00' ) 
           AND NAME_CARGO = 'Магнетитовая'
            ORDER BY D + T DESC
             ) 
            AND  D +  T <  '07.10.2014 23:00:00'  )       
            AND NAME_CARGO = 'Магнет. порожняк'

вложенный запрос отрабатывает хоть и медленно (3 с), но корректно

SQL
1
2
3
4
5
6
7
8
  SELECT
            FIRST 1 D + T  
            FROM PROTOKOL
            LEFT OUTER JOIN CARGO CARGO1 ON (PROTOKOL.FK_CARGO = CARGO1.ID_CARGO)
            WHERE 
          (D +  T >  '07.10.2014 8:00:00' AND D +  T <  '07.10.2014 20:00:00' ) 
           AND NAME_CARGO = 'Магнетитовая'
            ORDER BY D + T DESC
умные люди говорят что-то про вычисляемый столбец D + T ...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.10.2014, 11:55
Помогаю со студенческими работами здесь

Создание вычисляемого столбца в DataGridView
Доброго времени суток! Делаю приложение на WinForms для работы с БД в учебных целях, чтобы лучше освоить C#. Столкнулся с тем, что с...

перевод кода Delphi в формулу для вычисляемого столбца
Вот процедура, в которой вычисляется значение для поля: procedure TDM.BiletCalcFields(DataSet: TDataSet); begin a :=...

Фильтр для вычисляемого столбца(дата и время) в запросе
Добрый день. Есть вычисляемый столбец в запросе. Тип столбца: дата и время. Возможно ли сделать фильтр по месяцу(вывод дат только за январь...

Использование вычисляемого поля для условия в этом же запросе
Есть вот такой запрос: SELECT qryFIO.idCont, qryFIO.ShortFIO, TBLcommunicationContractors.idComPost, tblQstr_Answers.idQA, ...

Как правильно написать SELECT после THEN в конструкции CASE?
Имеется следующий работающий запрос: $q = mysql_query (&quot;SELECT supplies.id, supplies.zorder, supplies.type, CASE supplies.type ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru