-
MY PROJECTS
-
Recent Posts
- SpringBoot.Making our first starter and autoconfiguration
- Spring. Creating main annotation to start business logic
- Spring.Reading from properties file
- Spring.How to define spring version inside springBoot ?
- SpringBoot App inside Docker
- Kafka.FirstExperience
- Docker.MySql and Lost connection to MySQL server at ‘reading initial communication packet’, system error: 0
- Gradle.Tips
- Spring.AppConfig
- Leetcode.Best-time-to-buy-and-sell-stock
- LeetCode.ClimbStairs.Fibbonacci
- Leetcode.Roman-to-integer
- LeetCode.Palindrome-number
- Java.DesignPatterns.Lightweight
- Java.DesignPatterns.Proxy
- Java.DesignPatterns.Facade
- Java.DesignPatterns.Composite
- Java.DesignPatterns.Bridge
- Java. Strange OOP thing
- Java.Classpath
Categories
- Aptana
- Azure
- C#
- DataSnap
- DBExpress
- Delphi
- Delphi и сети
- Delphi. Язык программирования
- ExtJS
- FastReport
- FireDAC
- FireMonkey
- GIT
- ICS
- IDE
- IIS
- Indy
- InnoSetup
- javascript
- jQuery
- JSON
- LiveBindings
- MSHTML
- MySQL
- PHP
- REST
- Ribbons
- SMS
- SQL инструкции
- SVN
- TRichView
- UniGui
- WebBroker
- WinAPI
- Windows
- Алгоритмы
- Без рубрики
- Деревья
- Ищу ответ
- Компонентостроение
- Мои компоненты
- Начальный уровень
- Обработка исключений
- Парсинг
- Потоки(Threads)
- Регулярные выражения
- Тестирование приложений
Monthly Archives: August 2016
Delphi. TRichView. Как добавить изображение и сохранить его в базе в нормальном HTML формате?
В прошлом посте мы сохраняли в базу контент в HTML формате, но проблема была в том, что программа c TRichView копировала изображение в некую директорию и прописывала пути относительно неё. Оно и записывалось и читалось корректно, но в пределах одного … Continue reading
Delphi. TRichView. Как добавить изображение и сохранить его в базе ?
Разрабатываю небольшой компонент – текстовый редактор DBTextEditor, для своей программы . В базе данные будут храниться в HTML формате в обычном текстовом поле. У меня MySQL, я использую TEXT поле. Изображения будут храниться рядом с EXE – в отдельной папке … Continue reading
Программное добавление поля
Программное добавление поля, на примере ADO, по аналогии можно сделать и с FireDAC
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
var f: TIntegerField; begin ADOQuery.Open; f := TIntegerField.Create(ADOQuery); //Создаем поле тепа INTEGER f.FieldKind := fkLookup; //Указываем на то что оно у нас LookUp f.KeyFields := 'key_name'; //Поле ключ, по которому будет искаться соответствие f.LookupDataSet := ADOQueryDictionary; //Набор данных (DataSet) в котором буду отбираться данные f.LookupKeyFields := 'id'; //Уникальный ключ в наборе данных ADOQueryDictionary, по которому будем искать f.LookupResultField := 'name'; //Поле из набора данных ADOQueryDictionary, которое будет отображаться в результате f.Name := 'field_name'; //задаем имя нашему полю ADOQuery.Fields.Add(f); //включаем его в сотав нашего набора данных end; |
Posted in Delphi
Comments Off on Программное добавление поля
Delphi. FireDAC. FDTable. Осортировать записи на клиенте
Пример сортировки
1 2 3 4 5 6 7 8 |
procedure TVisualFrame.Sort; begin FDTable.IndexFieldNames:='ChangesDateTime:D'; FDTable.Close; FDTable.Open; end; |
Буква D означает по убыванию, Descending как я понимаю
Posted in Delphi
Comments Off on Delphi. FireDAC. FDTable. Осортировать записи на клиенте
Delphi. Как закрыть модальное окно программно?
Вопрос вроде бы простой, но стопорнулся на нём. В сети много примеров на эту тему, но перепробовав всё, я понял, что мне нужен свой вариант))) Проблема заключается в том, что вызвав модальную форму, программа ждёт некоторого действия от пользователя, например … Continue reading
Posted in Delphi
Comments Off on Delphi. Как закрыть модальное окно программно?
Delphi. Как настроить TListView для работы с большим количеством данных?
1 2 3 4 |
... private FSL:TStringList; ... |
Например 1000 000 строк…
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 |
procedure TForm1.FormCreate(Sender: TObject); var lc:TListColumn; i: Integer; begin FSL:=TStringList.Create; for i := 0 to 1000000 do FSL.Add('somevalue '+i.ToString()); //Вначале настроем массив //Вся настройка листвью тут //Виртуальный режим Listview1.OwnerData:=True; //Сделаем в виде колонок и добавим 2 колонки ListView1.ViewStyle:=vsReport; lc:=ListView1.Columns.Add; lc.Caption:='caption'; lc.Width:=150; lc:=ListView1.Columns.Add; lc.Caption:='test'; lc.Width:=150; //Ну и ещё пару моментов ListView1.RowSelect:=true; //Листвю должен знать, скоко у нас элементов. //Это число потом можно будет менять в процесе работы. ListView1.Items.Count:=FSL.Count-1; //Length(arr); //Листвью сам запросит нужные элементы, когда надо будет их отрисовать //Элементы запрашиваются в OnData Caption:=IntToStr(FSL.Count-1); //ListView1.UpdateItems(1,1); end; |
OnData
1 2 3 4 5 6 7 8 9 |
procedure TForm1.ListView1Data(Sender: TObject; Item: TListItem); begin //Этот обработчик должен выдавать элемент по номеру. //Точнее, есть Item, в которому нужно заполнить caption и subitems //Номер элемента храниться в Item.index item.Caption:=FSL[Item.Index]; // arr[item.Index].caption; item.SubItems.Add((FSL[item.Index])); end; |
После этого – информация подгружается по мере скролла – происходит это достаточно быстро.
Posted in Delphi
Comments Off on Delphi. Как настроить TListView для работы с большим количеством данных?
Delphi. Добавить DateTIme в MySQL в правильном формате.
Записать в нужном формате в MySQL
1 2 3 4 5 6 7 8 9 |
procedure TEventsListView.Test; var dateTimeForMySQL: string; begin ... dateTimeForMySQL := FormatDateTime('yyyy-mm-dd hh:mm:ss', Now); qUpdateDateTime.Params.ParamValues['DateTime'] := dateTimeForMySQL; ... end; |
Прочитать, соответственно, наоборот
1 |
dt := q.FieldByName('dt').AsDateTime; |
Posted in Delphi
Comments Off on Delphi. Добавить DateTIme в MySQL в правильном формате.