Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
15 / 15 / 0
Регистрация: 22.06.2018
Сообщений: 199

Нестандартный Datasnap

17.06.2020, 19:43. Показов 1440. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте всем!
У меня немного не стандартная ситуация. Проанализировав с yuotube и в инете информацию про Datasnap, прихожу к выводу, что в основном Datasnap используется в основном или в большинстве случаев при работе с базой данных.
У меня немного другая идея. У меня есть человек, который проходит тест на своем Пк, обращаясь к базе данных напрямую ,а для того, чтобы сравнить его ответ, то вызывается метод на Servere(метод расчета решения компьютером Head_Evaluating_expressions(s_file_locat ion,Mas_0_of_calculated_results), т.е. человек вводит свой ответ,а компьютер решает свое, потом отправляет ответ пользователю и далее принимается решение - решил человек или нет. Т.о. при обращении к серверу нет никакого взаимодействия к базе данных , но есть просто использование запроса, к серверу, так как именно на сервере хранятся формулы решений,а не на клиентском ПК.
Т.е. получается , что нужно вызвать метод из сервера и все будет работать, но к сожалению, этого не происходит, так как не знаю почему. Если у кого-то есть какие мысли, то , пожалуйста, скажите.
Алгоритм следующий : 1). Сделала DataSnap
Delphi
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
unit ServerMethodsCertification;
 
interface
 
uses System.SysUtils, System.Classes, System.Json,
    Datasnap.DSServer, Datasnap.DSAuth, DataSnap.DSProviderDataModuleAdapter,Vcl.Dialogs,
    Evaluating_expressions_1; // модуль -куда передается параметр и откуда потом возвращаются данные в виде массива строк
 
type
  TServerMethods1 = class(TDSServerModule)
  private
    { Private declarations }
  public
    { Public declarations }
    function EchoString(Value: string): string;
    function ReverseString(Value: string): string;
    procedure Head_Evaluating_expressions(s_1_file_location: string;
     var Mas_1_of_calculated_results:Vector_of_calculated_results);
  end;
 
 var ServerMethods1: TServerMethods1;
 
implementation
 
 
{$R *.dfm}
 
 
uses System.StrUtils, ServerContainer_Certification;
 
function TServerMethods1.EchoString(Value: string): string;
begin
  Result := Value;
end;
 
function TServerMethods1.ReverseString(Value: string): string;
begin
  Result := System.StrUtils.ReverseString(Value);
end;
 
procedure [B]TServerMethods1.Head_Evaluating_expressions(s_1_file_location: string;
  var Mas_1_of_calculated_results: Vector_of_calculated_results);[/B]
begin
   Head_0_Evaluating_expressions(s_1_file_location,
   Mas_1_of_calculated_results);
end;
 
end.
2). Сделал службы и запустил
3). Добавил форму к клиентскому приложению и положил TSQLConnection. Соединение все удачно.
Delphi
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
unit Connecting_to_Server;
 
interface
 
uses
  Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
  Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Data.DB, Data.SqlExpr, Data.DbxDatasnap,
  IPPeerClient, Data.DBXCommon, Datasnap.DBClient, Datasnap.DSConnect;
 
type
  TConnection_to_Server = class(TForm)
    SQLConnection1: TSQLConnection;
    DSProviderConnection1: TDSProviderConnection;
    procedure FormCreate(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;
 
var
  Connection_to_Server: TConnection_to_Server;
 
implementation
 
{$R *.dfm}
 
procedure TConnection_to_Server.FormCreate(Sender: TObject);
begin
  SQLConnection1.Open;
end;
 
end.
4).Когда делаю на клиентской форме TSQLConnection через правую кнопки мыши "Generate DataSnap client classes",то нет моего нового метода
Delphi
1
2
[B]TServerMethods1.Head_Evaluating_expressions(s_1_file_location: string;
  var Mas_1_of_calculated_results: Vector_of_calculated_results);[/B]
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
//
// Created by the DataSnap proxy generator.
//
 
unit ServerMethodsClient;
 
interface
 
uses System.JSON, Data.DBXCommon, Data.DBXClient, Data.DBXDataSnap, Data.DBXJSON, Datasnap.DSProxy, System.Classes, System.SysUtils, Data.DB, Data.SqlExpr, Data.DBXDBReaders, Data.DBXCDSReaders, Data.DBXJSONReflect;
 
type
  TServerMethods1Client = class(TDSAdminClient)
  private
    FEchoStringCommand: TDBXCommand;
    FReverseStringCommand: TDBXCommand;
  public
    constructor Create(ADBXConnection: TDBXConnection); overload;
    constructor Create(ADBXConnection: TDBXConnection; AInstanceOwner: Boolean); overload;
    destructor Destroy; override;
    function EchoString(Value: string): string;
    function ReverseString(Value: string): string;
  end;
Только есть демо-методы,а моего нет.
5).В другом файле клиентского приложения пытаюсь вызвать его, но не вызывается, так как нет его на шаге 4! Зато методы "EchoString" и "ReverseString" есть.
6). Думал, может через класс какой-то сделать и передавать, но вроде бы и так должно работать,но не пока так не пробовал.
Просто, если бы методы подхватились на TSQLConnection через кнопку "Generate DataSnap client classes", то вопросов не было, так как , когда я в приложении пытаюсь
Delphi
1
SMC:TServerMethods1Client;
, то при вызове

SMC.Head_Evaluating_expressions(s_1_file _location: string;
var Mas_1_of_calculated_results: Vector_of_calculated_results); должно работать, но не факт, так как его просто нет при генерации . Если кто сталкивался с таким(добавлении клиентской процедуры на сервере, то , пожалуйста, прошу помочь!
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
17.06.2020, 19:43
Ответы с готовыми решениями:

DataSnap и БД
Добрый день! Кто нить работал с DataSnap и БД, Нашел статью как работать и пример, сервер запустил клиент тоже но к таблице не...

DataSnap + MySQL
Здравствуйте. Передо мной стоит задача создать трехзвенное клиент-серверное приложение на тему "Автоматизация кассы автовокзала"...

Ликбез по DataSnap
Всех приветствую, предлагаю открыть дисскусию по теме технологии DataSnap (трехзвенка от создателей delphi) интересна любая...

6
5975 / 4550 / 1095
Регистрация: 29.08.2013
Сообщений: 28,172
Записей в блоге: 3
17.06.2020, 20:35
в вашем случае DataSnap то зачем?

Зачем компьютеры решать тест? тест же задается сразу с правильными ответами
0
15 / 15 / 0
Регистрация: 22.06.2018
Сообщений: 199
19.06.2020, 00:02  [ТС]
Цитата Сообщение от qwertehok Посмотреть сообщение
Зачем компьютеры решать тест? тест же задается сразу с правильными ответами
Все просто мои ученики будут решать тесты, которые будут стоять у меня на компьютере. Тест - не совсем тест, а задача, которую решает и вычисляет компьютер,а потом идет сравнение ученика и компьютера. Я же не могу дать сразу ответы с решенными тестами ученикам, тогда я никак не проверю знания своих учеников.) Просто DataSnap - как калькулятор, где есть формулы, выражения и прочее, а на стороне клиента ничего, кроме мозгов по точным наукам.)
0
 Аватар для Пытливый
3763 / 2267 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
19.06.2020, 07:39
Лучший ответ Сообщение было отмечено Alexey-PK как решение

Решение

Не занимался этой темой, но предположу, что видимым методом может быть только функция возвращающая результат, а у вас процедура. Попробуйте изменить ее на функцию.
1
5975 / 4550 / 1095
Регистрация: 29.08.2013
Сообщений: 28,172
Записей в блоге: 3
19.06.2020, 08:36
Цитата Сообщение от Alexey-PK Посмотреть сообщение
Я же не могу дать сразу ответы с решенными тестами ученикам, тогда я никак не проверю знания своих учеников.)
вы сейчас серьезно?
представьте себе систему тестирования, вы думаете там сидит человек и сравнивает каждый ответ с правильным?

Цитата Сообщение от Alexey-PK Посмотреть сообщение
Просто DataSnap - как калькулятор, где есть формулы, выражения и прочее, а на стороне клиента ничего, кроме мозгов по точным наукам
вот именно, на стороне клиента только подключение к серверу DS
никакого прямого коннекта к БД
1
15 / 15 / 0
Регистрация: 22.06.2018
Сообщений: 199
20.06.2020, 01:04  [ТС]
Цитата Сообщение от Пытливый Посмотреть сообщение
Не занимался этой темой, но предположу, что видимым методом может быть только функция возвращающая результат, а у вас процедура. Попробуйте изменить ее на функцию.
Да, согласен с Вами. Сегодня думал об этом полдня. Буду так и делать, но я потом отпишусь, что и как, так как с функциями передачи класса разобрался, надо будет создать функцию, потом вызвать процедуру,передав строку , потом обработать там и возвратить класс строк. Дума работать в этом направлении после субботы.)

Добавлено через 15 минут
Цитата Сообщение от qwertehok Посмотреть сообщение
вы сейчас серьезно?
представьте себе систему тестирования, вы думаете там сидит человек и сравнивает каждый ответ с правильным?
Да, верно. Есть ученик, который хочет поступить на бюджет и ему нужен высокий балл по ЕГЭ. Я в конце обучения предлагаю ему нестандартные задачи, которые он , решая (полагаю), что решит самые сложные задачи экзамена.
Эта система не на продажу пойдет, так как полагаю, что она навряд ли кому-то нужна будет. Просто для моих учеников и все.

Цитата Сообщение от qwertehok Посмотреть сообщение
вот именно, на стороне клиента только подключение к серверу DS
никакого прямого коннекта к БД
Не знаю, я думал, чтобы не подвешивать сервер, то клиент обращается напрямую к БД, а к DS обращается для сравнения ответа и все,т.е. DS- Как калькулятор формул и все,а так обращаться к DS, потом он к БД, не знаю, мне ,кажется, будет немного трудозатратно,но может и ошибаюсь.
0
15 / 15 / 0
Регистрация: 22.06.2018
Сообщений: 199
24.06.2020, 00:40  [ТС]
Цитата Сообщение от Пытливый Посмотреть сообщение
Не занимался этой темой, но предположу, что видимым методом может быть только функция возвращающая результат, а у вас процедура. Попробуйте изменить ее на функцию.
Вы знаете, тут иное. Смотрю на это две недели и не понимаю, почему часть подцепляется функция,а моя никак, но сегодня вручную ввел процедуру и ничего не написал внутри и вызвал ее в другом модуле и она стала доступна для вызова, но как ее в параметрах ее обозначить пока не знаю, а делать ее пустой не верно, но пока подбором.
Но процедуры можно задавать , но как , чтобы подцеплялись пока космос... который нельзя понять, но подумаю еще недею-две и напишу конечно же - или можно или нет! И с процедурами , чтобы никто не лез в DataSnap!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
24.06.2020, 00:40
Помогаю со студенческими работами здесь

RAD2010+технология DataSnap
Кто нибудь работал с БД по этой технологии? Вопрос в следующем создаю TDSServerModule1 на серверном приложении. в publik-e описываю...

Развёртывание DataSnap-приложения
Здравствуйте! Помогите в развёртывании DataSnap-приложения. C MSSQL пока не очень дружусь но из-за проблем хостинга пришлось перейти...

DataSnap Сервер-Клиент подключение клиентов к БД
Добрый день! Необходимо чтобы клиенты после подключения к серверу по локальной сети получали некоторые данные из БД. И по завершению работы...

MIDAS (DataSnap), ошибка Provider cannot be found
Добрый день, форумчане. Появилась проблемка, я решил попробовать себя в разработке приложений для работы с БД. Цель такая, написать...

Datasnap. Не могу сделать select, update
создаю DataSnap трёхзвенку. Delphi 10.2, firebird 3 использую методы сервера. связка на сервере:...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это дополнительная запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
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
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru