Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/40: Рейтинг темы: голосов - 40, средняя оценка - 4.60
2 / 5 / 1
Регистрация: 14.05.2013
Сообщений: 99

FireDac + DLL

07.10.2021, 16:56. Показов 8108. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет!

Пытаюсь использовать внутри DLL компоненты FireDAC. База данных - SQLite. Вызывающее приложение сыпется с исключением
Код такой:

C++
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
void __cdecl GetCoefficent(float *result)
{
TFDConnection *DBConnection;
    TFDQuery *Query;
    try
    {
 
        DBConnection = new TFDConnection(DBConnection);
        DBConnection->Params->Add("DriverID=SQLite");
        DBConnection->Params->Add("Database=db.db");
        DBConnection->Params->Add("OpenMode=ReadOnly");
        DBConnection->LoginPrompt = false;
 
        DBConnection->Open();
        Query = new TFDQuery(NULL);
        Query->SQL->Clear();
        Query->SQL->Add("SELECT * FROM table;");
        Query->Open();
        Query->First();
        float m = Query->FieldByName("field")->Value;
 
        *result = m;
    }
    catch(...)
    {
        return;
    }
    DBConnection->Free();
    TypesQuery->Free();
}
В мануале на сайте Embarcadero написано, что нужно каким-то образом использовать
C++
1
TFDConnection->SharedCliHandle
А что именно с ним делать, что туда присваивать я не пойму

Вызывающая DLL программа написана на C#
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
07.10.2021, 16:56
Ответы с готовыми решениями:

Widememo и FireDAC
Использую FireDAC. База данных PostgreSQL. Если тип колонки в базе TEXT, то в гриде вместо текста пишет WIDEMEMO. Хотелось бы увидеть...

FireDAC - что это ?
Embarcadero объявляет о выходе FireDAC – технологии для доступа к данным масштаба предприятия с различных устройств FireDAC. Работа с...

Параметризированный запрос к FireDAC ExecSQL
Здравствуйте, помогите разобраться как передать параметры в запрос. Например в Delphi параметризированный запрос описывается так: ...

4
2 / 5 / 1
Регистрация: 14.05.2013
Сообщений: 99
12.10.2021, 21:04  [ТС]
При попытке напрямую использовать sqlite3.dll ругается на имена функций:
[ilink32 Error] Error: Unresolved external '_sqlite3_exec' referenced from RJM_SQLITE_RESULTSET.OBJ
[ilink32 Error] Error: Unresolved external '_sqlite3_free' referenced from RJM_SQLITE_RESULTSET.OBJ
Помогите!!!!
0
Модератор
 Аватар для D1973
9923 / 6459 / 2457
Регистрация: 21.01.2014
Сообщений: 27,409
Записей в блоге: 3
13.10.2021, 06:01
Цитата Сообщение от doomkin Посмотреть сообщение
Вызывающее приложение сыпется с исключением
и выглядит оно как-то вот так, да?



Цитата Сообщение от doomkin Посмотреть сообщение
DBConnection = new TFDConnection(DBConnection);
мне вот очень интересно, что это там за параметр в скобках... Сможете объяснить?
0
2 / 5 / 1
Регистрация: 14.05.2013
Сообщений: 99
13.10.2021, 11:28  [ТС]
Цитата Сообщение от D1973 Посмотреть сообщение
мне вот очень интересно, что это там за параметр в скобках... Сможете объяснить?
Это описка. В проекте я туда NULL передаю.

Во вложении и проект DLL и тестовый проект на C#
Вложения
Тип файла: zip _to_forum.zip (13.32 Мб, 5 просмотров)
0
2 / 5 / 1
Регистрация: 14.05.2013
Сообщений: 99
15.10.2021, 14:29  [ТС]
Разобрался, наконец!
Чтобы заработала база, нужно было приинклудить эти два заголовка:
C++
1
2
#include <FireDAC.Comp.UI.hpp>
#include <FireDAC.VCLUI.Wait.hpp>
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
15.10.2021, 14:29
Помогаю со студенческими работами здесь

FireDac. Редактирование записей в таблице
Добрый день. Работаю с БД Access через FireDac. Необходимо редактировать записи в таблицах. Нашел вроде бы простой способ как это...

FIREDAC + Access. Ошибка Drop Table
Здравствуйте. Пытаюсь удалить таблицу из БД Access: FDTable1-&gt;Close(); FDTable2-&gt;Close(); FDTable3-&gt;Close(); SQLText...

ADO, FireDAC Создание структуры для запроса
Доброго! Узнал что в FireDac (а скорее всего так же и в ADO) можно создавать структуры запроса, что ускоряет обмен данными,а так же...

Обновление таблицы БД, после обновления данных в StringGrid. FireDAC
Добрый день. Есть форма (скрин приложил), подключена БД(mySQL) через FDConnection, через FDQuery заполняется скриптом StringGrid...

Как через FireDAC TFDQuery получить имена таблиц присутствующих в базе к которой я подключился ?
Всем привет. Раньше пользовал компонент стороннего разработчика MyDAC и просто в SQL запросе TMyQuery указаывал 'show tables' и...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru