Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / Delphi [игнор отключен] [закрыт для гостей] / Параметизированный в классе / 6 сообщений из 6, страница 1 из 1
18.11.2017, 21:39:41
    #39555587
Sashaua
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Параметизированный в классе
Подскажите.
Есть метод в классе для выполнения запросов.

Код: pascal
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
procedure TClients.getSQLrequest(sql: string);

begin
 with fDataModule_modelwork do begin
  try
  if IBQuery_SQLrequest.Transaction.Active then IBQuery_SQLrequest.Transaction.Active:=false;
  if IBQuery_SQLrequest.active then IBQuery_SQLrequest.Close;
  IBQuery_SQLrequest.SQL.Clear;
  IBQuery_SQLrequest.SQL.Add(sql);
  IBQuery_SQLrequest.Open;
  except
  on e: exception do
  MessageDlg('Ошибка выполнения запроса'+#13#10+e.message, mtError, [mbOk], 0);
  end;
 end;
end;


Есть методы которые дергаются для выборок .
пример:
Код: pascal
1.
2.
3.
4.
procedure TClients.getClients_list();
begin
getSQLrequest('select ID,NAME from CLIENTS');
end;



Как в данной схеме реализовать параметризированные запросы.
Код: sql
1.
2.
select ID,NAME from CLIENTS where id=:id_client
ParamByName ('id_client').asinteger:=100;


не хочется в запрос передавать переменные, например
Код: pascal
1.
 getSQLrequest('select ID,NAME from CLIENTS where  id:='+id_client);


если выборка большая с кучи таблиц, сам запрос будет сложно читаемым
Возможно есть что-то типа такого.

Код: sql
1.
2.
3.
4.
5.
6.
7.
clients_query_method(){
Sql.AddQuery('select ID,NAME from CLIENTS where id=:id_client')
Sql.AddParam('id'):=100;
}

getClients_list() {
general_sql(clients_query_method)
...
Рейтинг: 0 / 0
18.11.2017, 22:18:58
    #39555588
Гхостик
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Параметизированный в классе
Код: pascal
1.
const AParamValues: TDictionary<string, variant>
...
Рейтинг: 0 / 0
19.11.2017, 03:02:02
    #39555601
Sashaua
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Параметизированный в классе
Гхостик
Код: pascal
1.
const AParamValues: TDictionary<string, variant>


А можно детальнее,гуглонул не совсем разобрался
...
Рейтинг: 0 / 0
19.11.2017, 06:17:11
    #39555614
krapotkin
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Параметизированный в классе
вообще как-то не очень
if IBQuery_SQLrequest.Transaction.Active then IBQuery_SQLrequest.Transaction.Active:=false;
если у вас транзакция активна, то она должна завершиться либо Commit либо Rollback
а Active=false это "на кого бог пошлет", в зависимости от того, что там установлено


Код: pascal
1.
2.
IBQuery_SQLrequest.SQL.Clear;
  IBQuery_SQLrequest.SQL.Add(sql);


это бы тоже заменить на простое
Код: pascal
1.
IBQuery_SQLrequest.SQL.text := sql;



ну а для того, чтобы ваш запрос выполнялся с параметрами, нужно как-то обеспечить
1) передачу этих параметров в процедуру, например как предложено выше через TDictionary<string, variant>
(мне больше нравится вариант просто TList или TObjectList из объектов ключ-значение, но не суть...)
2) внутри нужно стереть старые параметры и в цикле установить значения новых в соответствии с переданной структурой
Код: pascal
1.
query.paramByName(key).asVariant := value;
...
Рейтинг: 0 / 0
19.11.2017, 10:58:29
    #39555629
Гхостик
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Параметизированный в классе
Можно вообще array of const чтобы не возиться с выделением памяти на объект-коллекцию, имена и значения по очереди в одномерном массиве.
...
Рейтинг: 0 / 0
20.11.2017, 01:47:53
    #39555881
Sashaua
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Параметизированный в классе
krapotkin,
а можно пример реализации, не смог разобраться самостоятельно.
...
Рейтинг: 0 / 0
Форумы / Delphi [игнор отключен] [закрыт для гостей] / Параметизированный в классе / 6 сообщений из 6, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]