Перейти из форума на сайт.

НовостиФайловые архивы
ПоискАктивные темыТоп лист
ПравилаКто в on-line?
Вход Забыли пароль? Первый раз на этом сайте? Регистрация
Компьютерный форум Ru.Board » Компьютеры » Прикладное программирование » Embarcadero RAD Studio

Модерирует : ShIvADeSt

 Версия для печати • ПодписатьсяДобавить в закладки
Страницы: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322

Открыть новую тему     Написать ответ в эту тему

V1s1ter



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
         
Обсуждаем новые возможности и баги
 
Просьба писать про Embarcadero RAD Studio XE5, XE6, XE7, XE8, 10.x (Seattle, Berlin,Tokyo)
  По вопросам скачивания - Тема в Варезнике (lite-версии тут)
  Вопросы по неюникодным версиям Delphi — шестая бумага
  Бесплатные Компоненты и утилиты для Delphi/BCB/FreePascal/Lazarus
  Коммерческие компоненты и утилиты для Delphi/BCB
  Вопросы по компонентам для Delphi, C++ Builder разных версий
  Новые языковые возможности, начиная с Delphi 2005 по XE4 — здесь, и New!здесь еще
  Англоязычный официальный форум Embarcadero — здесь
  Embarcadero Quality Central, веб интерфейс — здесь, новый Quality Portal тут
  Программирование на Delphi — викиверситет
  Другие ресурсы
   Предыдущие бумаги
 
     Вопросы ..XE4       Вопросы ..XE3    Вопросы ..XE2      
  Вопросы ..2009-XE    Вопросы ..<2009 / ч.5    Вопросы ..<2009 / ч.4      
  Вопросы ..<2009 / ч.3    Вопросы ..Delphi 2 / ч.2    Вопросы ..Delphi  

  Выключение встроенного эксперта Castalia  для XE8 (иногда помогает при вылетах и тормозах)  
  Полезные плагины(эксперты)

Всего записей: 948 | Зарегистр. 06-02-2007 | Отправлено: 15:25 11-09-2013 | Исправлено: Komandor, 18:58 18-03-2022
reenoip



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Steepe_Hare, да это вроде уже месяц как не секрет

Всего записей: 1768 | Зарегистр. 10-03-2006 | Отправлено: 14:37 10-09-2016
VadimLou



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
ItsJustMe

Цитата:
ы! Как вы понимаете, дело отнюдь не в том, что ископаемое 2007 не может чего-то, что может ископаемое 7. Даже для столь замечательного продукта, как ископаемые, было бы странно предположить, что более поздние версии имеют меньше возможностей,

2007 - уникальная версия. Последняя в которой есть Dot.Net. Последняя ANSI версия компилятора. Новейшие версии этого уже не могут

Всего записей: 702 | Зарегистр. 22-07-2004 | Отправлено: 23:02 10-09-2016 | Исправлено: VadimLou, 23:05 10-09-2016
KDPoid



Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Delphi 10.1 и FireDAC его.
SQLite.
Я, с уровнем познаний: "Ух ты, как тут всё забавно."
 
По привычке, леплю TFDConnection, цепляю к базе.
Кладу TFDTable, указываю таблицу, активирую, заполняю поля.
 
В design-time всё ок.
TFDTable.Filtred = false;
TFDTable.Filter = '';
 
В рантайме...
    FDTable1.Filtered := False;
    FDTable1.Filter := 'F_ID = 1';
    FDTable1.Filtered := True;
// Пока всё норм...
    FDTable1.Filtered := False;
    FDTable1.Filter := 'F_ID = 2';
    FDTable1.Filtered := True; // Вот тут трапается.
// AEx.FMessage: '[FireDAC][Phys][SQLite] ERROR: unrecognized token: "2and"'
 
Я озадачен...  
 
Таблица в SQLite:
CREATE TABLE [CHA] (
    [ID] integer NOT NULL PRIMARY KEY AUTOINCREMENT,  
    [YEAR] integer NOT NULL DEFAULT 0,  
    [F_ID] int NOT NULL
);
 
Записи в таблице есть с обоими значениями F_ID, селекты проходят, на разрушение базы грешить не с руки.
 
F_ID даже не PK, как оно может мешать "распознать токен"?  
IndexFieldNames определся сам, и там "ID".
В Items fiMeta присутствует...
 
ЧЯДНТ?

Всего записей: 404 | Зарегистр. 08-08-2006 | Отправлено: 08:03 11-09-2016 | Исправлено: KDPoid, 08:55 11-09-2016
kaz_av

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
VadimLou

Цитата:
2007 - уникальная версия. Последняя в которой есть Dot.Net.

В 2009 есть dotnet.

Всего записей: 437 | Зарегистр. 15-02-2006 | Отправлено: 10:10 11-09-2016
VadimLou



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
kaz_av Боже , как давно это было ... забылось. Может с помощью LLVM восстановят...

Всего записей: 702 | Зарегистр. 22-07-2004 | Отправлено: 21:19 11-09-2016
Steepe_Hare



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Появилась задача написать небольшое приложение под Андроид на Embarcadero Delphi - чат внутри организации (отправка сообщений, картинок и проч.)
Как технически реализовать? Какие ресурсы почитать?
Я так понял, нужен сервер, к которому должна при запуска коннектиться программа, чтобы видеть, кто в сети и т.д.

Всего записей: 1162 | Зарегистр. 27-10-2001 | Отправлено: 21:30 11-09-2016
ZloyBrawler



Full Member
Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
Steepe_Hare
http://www.commfort.com/ru/

Всего записей: 514 | Зарегистр. 19-10-2010 | Отправлено: 21:42 11-09-2016
Steepe_Hare



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
ZloyBrawler
 
Нет, нужно свое решение со своими нюансами

Всего записей: 1162 | Зарегистр. 27-10-2001 | Отправлено: 21:51 11-09-2016
ZloyBrawler



Full Member
Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
Steepe_Hare
все это от лукавого

Всего записей: 514 | Зарегистр. 19-10-2010 | Отправлено: 21:53 11-09-2016
VadimLou



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Steepe_Hare
Delphi Firemonkey demos on Github
https://github.com/FMXExpress/Firemonkey
BlueChat

Всего записей: 702 | Зарегистр. 22-07-2004 | Отправлено: 22:58 11-09-2016
Steepe_Hare



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
VadimLou
 
 
Спасибо, неплохая подборка демок

Всего записей: 1162 | Зарегистр. 27-10-2001 | Отправлено: 04:47 12-09-2016
Dronton2

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
KDPoid
Фильтры строятся следующим образом:
1. В SQL-запросе выделяется условие "WHERE" и заключается в скобки
2. К получившейся строке добавляется условие фильтра через ключевое слово "AND"
Видимо, после вашего условия и перед AND, компонент не поставил пробел, и двойка приклеилась к ключевому слову. Появляется подозрение, что компонент не очистил условие SQL-запроса после смены фильтра.
Попробуйте посмотреть чем-нибудь: какой текст SQL-запроса передаётся из вашей программы в базу данных. Тогда станет понятно, где ошибка.

Всего записей: 460 | Зарегистр. 27-06-2005 | Отправлено: 10:13 12-09-2016
KDPoid



Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Ошибка выловлена, подозрения с FireDAC сняты.

Всего записей: 404 | Зарегистр. 08-08-2006 | Отправлено: 07:08 13-09-2016
zealotfan



Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
KDPoid
Так в чём была ошибка? Интересно же

Всего записей: 234 | Зарегистр. 25-02-2016 | Отправлено: 07:14 13-09-2016
KDPoid



Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Причина - много кода написанного разными людьми... =)
 
Наставил брякпоинтов внутри FireDAC, отловил в его prepare селект, в котором пропускается пробел, увидел, что он не имеет ни какого отношения к данным, которые я фильтрую, но там делается выборка из таблицы, связанной с моей по FK. Сходил к тем датасетам, там и увидел обработчики событий, в которых лепятся фильтры, один из которых как раз и добавляет к фильтру and без ведущего пробела.  
Стоило поверить, что происходящее - не баг FD, и дело пошло на лад.

Всего записей: 404 | Зарегистр. 08-08-2006 | Отправлено: 12:55 13-09-2016
SolidSnakeRU

Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
FD (AD) на самом деле исключительно качественный продукт.
Жаль что теперь нельзя поддержать разработчиков AD покупкой лицензии.
Будь все составляющие delphi на таком уровне, делфи был бы просто другой.. лучший из лучших.

Всего записей: 248 | Зарегистр. 27-08-2008 | Отправлено: 15:26 15-09-2016
asutp2

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
SolidSnakeRU, можно поддержать покупкой лицензии самой делфи

Всего записей: 785 | Зарегистр. 22-10-2004 | Отправлено: 16:52 15-09-2016
KDPoid



Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Ещё про великолепный FireDAC...
 
Те же, там же.
Delphi 10.1 и FireDAC его.
SQLite.  
 
В SQLite-таблице поле типа DATE.
Там лежит значение '2015-09-03 00:00:00'
 
В приложении:
TFDConnection - TFDTable - TDataSource
 
В TFDTable поле распозналось и создало:
TFDTable1DATE: TDateField;
 
К датасорсу цепляю TcxGridDBTableView, создаю в нём поле DateEdit.
Всё отлично отображается... пока я не начинаю редактировать.
Если я попытаюсь изменить дату и установить её в приложении, то третье сентября сохранится в базе как '41885'.
Моё-то приложение и после этого продолжает нормально извлекать данные и отображать эту дату как третье сентября, но вот остальные...  
Другой софт сразу начинает верещать: "Да вы мыла поели! Идите почитайте, как надо хранить дату в SQLite!"
 
Что мне нужно сделать, чтобы FD засунул поглубже свою креативность и строже следовал спецификациям баз, с которыми работает?

Всего записей: 404 | Зарегистр. 08-08-2006 | Отправлено: 13:39 17-09-2016 | Исправлено: KDPoid, 13:39 17-09-2016
zedxxxx

Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Это не креативность и FD вполне следует спецификации. В SQLite дату можно хранить сразу тремя способами:

Цитата:
SQLite does not have a storage class set aside for storing dates and/or times. Instead, the built-in Date And Time Functions of SQLite are capable of storing dates and times as TEXT, REAL, or INTEGER values:
 
    TEXT as ISO8601 strings ("YYYY-MM-DD HH:MM:SS.SSS").
    REAL as Julian day numbers, the number of days since noon in Greenwich on November 24, 4714 B.C. according to the proleptic Gregorian calendar.
    INTEGER as Unix Time, the number of seconds since 1970-01-01 00:00:00 UTC.  
 
Applications can chose to store dates and times in any of these formats and freely convert between formats using the built-in date and time functions.

https://www.sqlite.org/datatype3.html
 
Добавлено:
И кстати, с точки зрения производительности, INTEGER тип будет оптимальным для дат.

Всего записей: 50 | Зарегистр. 08-11-2015 | Отправлено: 14:52 17-09-2016 | Исправлено: zedxxxx, 14:52 17-09-2016
KDPoid



Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
zedxxxx

Цитата:
INTEGER as Unix Time, the number of seconds since 1970-01-01 00:00:00 UTC.  

Я перевожу как "Количество секунд, прошедшее с 1 января 1970"
Между 03/09/2015 и 01/01/1970 прошло 16681 день.  
Умножаем на 24 и на 60 два раза.
Получаем: 1441238400
Именно это число сохраняет, например, SQLite Studio. (Если я живу по UTC )
 
А 41885 - это 1970-01-01 16:38:05
 
 
select julianday('2015-09-03');
-----------------------------------
2457268.5
 
 
Так по какой спецификации FD получает из 3 сентября - 41885?
 
 

Всего записей: 404 | Зарегистр. 08-08-2006 | Отправлено: 16:01 17-09-2016
Открыть новую тему     Написать ответ в эту тему

Страницы: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322

Компьютерный форум Ru.Board » Компьютеры » Прикладное программирование » Embarcadero RAD Studio


Реклама на форуме Ru.Board.

Powered by Ikonboard "v2.1.7b" © 2000 Ikonboard.com
Modified by Ru.B0ard
© Ru.B0ard 2000-2024

BitCoin: 1NGG1chHtUvrtEqjeerQCKDMUi6S6CG4iC

Рейтинг.ru