crossplatform.ru

Здравствуйте, гость ( Вход | Регистрация )

> SQLite функция обратная strftime()
Litkevich Yuriy
  опции профиля:
сообщение 13.2.2013, 12:48
Сообщение #1


разработчик РЭА
*******

Группа: Сомодератор
Сообщений: 9669
Регистрация: 9.1.2008
Из: Тюмень
Пользователь №: 64

Спасибо сказали: 807 раз(а)




Репутация:   94  


Есть ли в SQLite фнкция которая позволяет получить "SQLite дату" из произвольной строки (из значения поля)?

strftime() позволяет получить из "SQLite даты" произвольно форматированную строку, например:
strftime("%Y.%m.%d", 'now')
даст 2013.02.13

а у меня ситуация наоборот, есть в поле ("Date") некой таблицы строка 2013.02.13 и мне её нужно преобразовать к "SQLite дате", т.е. к 2013-02-13.

Если я делаю просто:
cast("Date" as Date)
то получаю ерунду (2013,02)

Поиск по интернету пока не даёт результата.

Реализация должна быть только средствами SQL (применительно к SQLite)
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
 
Начать новую тему
Ответов
Litkevich Yuriy
  опции профиля:
сообщение 15.2.2013, 14:49
Сообщение #2


разработчик РЭА
*******

Группа: Сомодератор
Сообщений: 9669
Регистрация: 9.1.2008
Из: Тюмень
Пользователь №: 64

Спасибо сказали: 807 раз(а)




Репутация:   94  


как оказалось, собака была зарыта тут:
Цитата(Litkevich Yuriy @ 13.2.2013, 14:48) *
cast("Date" as Date)
Хотя вообще поведения Лайта стремнее некуда.
Дело в том что в нём нет типа Date, но он, собака страшная, хоть бы ругнулся на это приведение. Ан нет, чёт своё выплюнул молчком.
Сейчас так делаю:
Сначала точки на чёрточки меняю:
replace(b."date", ".", "-")

ну а потом сравниваю так:
(date("Date") >= date('now', '-7 day'))

если функцию date() не использовать, то ересь получается, т.к. сравнивает просто строковые величины
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение

Сообщений в этой теме


Быстрый ответОтветить в данную темуНачать новую тему
Теги
Нет тегов для показа


3 чел. читают эту тему (гостей: 3, скрытых пользователей: 0)
Пользователей: 0




RSS Текстовая версия Сейчас: 1.12.2024, 9:13