Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2007.08.26;
Скачать: CL | DM;

Вниз

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;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.024 c
1-1181772512
SkySpeed
2007-06-14 02:08
2007.08.26
Как нормально определить каждое "слово" в коде?..


2-1186077051
Мануха
2007-08-02 21:50
2007.08.26
scroll в chart


15-1185207849
Nikfel
2007-07-23 20:24
2007.08.26
Как платить за размер в интернете.


15-1185435461
Autokont
2007-07-26 11:37
2007.08.26
1С и Vista


1-1181834100
DevilDevil
2007-06-14 19:15
2007.08.26
Один пункт меню в нескольких меню. Как ?