Главная страница
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.027 c
9-1156239437
VitaWED
2006-08-22 13:37
2007.08.26
Большие сцены в OpenGL


9-1158659677
Slavikkk
2006-09-19 13:54
2007.08.26
Автовыключение в ODE


1-1182243710
DrAndrew
2007-06-19 13:01
2007.08.26
Ошибка #10061 у IdHTTP1. Как исправить?


2-1185958244
\/iKTOR
2007-08-01 12:50
2007.08.26
Гафическое связывание таблиц


2-1185955901
Glivera
2007-08-01 12:11
2007.08.26
Создание формы