Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Начинающим";
Текущий архив: 2007.08.26;
Скачать: [xml.tar.bz2];

Вниз

Integer в минуты средствами SQL в MSSQL   Найти похожие ветки 

 
mfender ©   (2007-07-30 01:02) [0]

Собственно, вопрос такой: каким образом без особых затей сделать из целого числа (Int) время в SQL-запросе. Например, есть поле типа DateTime (Field1), значение которого нужно увеличить на 20 минут. Эти 20 минут написанны в соседнем поле, типа Integer (Field2). Т.е., конструкция такая:

SELECT Field1 + Field2 AS Res

Все потуги свелись к тому, что Res - дата-время на 20 дней больше, чем Field1. Чего и следовало ожидать. И никак не могу найти, как преобразовать средствами T-SQL эти "20" к "20 минутам".


 
ЮЮ ©   (2007-07-30 06:08) [1]

SELECT (Field1 + Field2/1440
 1440 - магическое число Хранителей Времени. И, как ни странно, именно столько минут в одних сутках.


 
mfender ©   (2007-07-30 08:12) [2]

Вот всё бы хорошо (действительно, как это я сразу не смекнул о таком простом и незатейливом вычислении), но есть одно НО. В справочке к MSSQL написано про оператор деления буквально следующее:

Если целочисленный аргумент dividend делится на целочисленный аргумент divisor, то результатом будет целое число, а дробная часть будет усечена.


Таким образом, выражение SELECT Field1 + 20/1440 FROM tableName теряет всякий смысл, т.к. целая часть деления 20 на 1440 всегда будет равна 0.


 
Anatoly Podgoretsky ©   (2007-07-30 08:35) [3]

> mfender  (30.07.2007 08:12:02)  [2]

А не хочешь попробовать делить на дробное



Страницы: 1 вся ветка

Форум: "Начинающим";
Текущий архив: 2007.08.26;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.44 MB
Время: 0.044 c
2-1186383567
Yekver
2007-08-06 10:59
2007.08.26
Dll с иконками


15-1185473815
sdarqweqwe
2007-07-26 22:16
2007.08.26
настройка windows


2-1185038984
Ivolg
2007-07-21 21:29
2007.08.26
TCPServer и TCPClient


15-1185860176
Кирей
2007-07-31 09:36
2007.08.26
как победить рутинные операции


15-1185366116
Vlad Oshin
2007-07-25 16:21
2007.08.26
по 1с не поможите? ТЗ.НайтиЗначение не работает что-то..





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский