Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2006.12.17;
Скачать: CL | DM;

Вниз

Почему при Commit e транзакции, свойства Active меняется?   Найти похожие ветки 

 
Sanya_BBB   (2006-10-09 23:00) [0]

Почему при Commit"e транзакции, свойства Active  у всех компонентов  IBQuery становятся False?
Я так думаю из за того что у меня один компонент IBTrancaction и 8 компонентов IBQuery и у всех указана только эта одна транзакции. Что нужно делать в таких ситуациях? Использовать для каждого IBQuery свой компонент IBTrancfction?


 
Zacho ©   (2006-10-09 23:14) [1]

Рекомендую изучить http://www.ibase.ru/devinfo/ibx.htm , а так же и остальные статьи на http://www.ibase.ru/develop.htm


 
unknown ©   (2006-10-09 23:21) [2]

http://www.ibase.ru/devinfo/ibx.htm да и вообще http://www.ibase.ru/
p.s.
пора уже повесить ссылку на ibase.ru, что бы сначала там искали перед
тем, как вопросы задавать.


 
DrPass ©   (2006-10-09 23:31) [3]


> Я так думаю из за того что у меня один компонент IBTrancaction
> и 8 компонентов IBQuery и у всех указана только эта одна
> транзакции. Что нужно делать в таких ситуациях?

Закрытие транзакции приводит к закрытию ее источников данных. В идеале действительно следует использовать несколько транзакций. Одну - только для чтения, и ее можно вообще не закрывать, другие - для изменения данных. Их наоборот, не следует держать открытыми долгое время. Открыл, выполнил операцию изменения, закрыл


 
Sanya_BBB   (2006-10-10 13:31) [4]

DrPass ©   (09.10.06 23:31) [3]

Так например у меня один компонент IBQuery, то как мне его соеденить сразу с двумя транзакциями? Или при измененении данных переприсваивать транзакцию? Например так:

перед добавлением данных присвоить компоненту  Query1 вторую транзакцию:

datamodule2.IBQuery1.Transaction:=datamodule2.IBTransaction2;
datamodule2.IBTransaction2.start;
datamodule2.IBQuery1.SQL.Clear;
datamodule2.IBQuery1.SQL.Add("insert into access_table(user_fio, user_pass, user_role) values("+fio+","+pass+", "+role+")");
datamodule2.IBQuery1.Open ;
datamodule2.IBTransaction2.commit;

А потом опять присвоить первую транзакцию:

datamodule2.IBQuery1.Transaction:=datamodule2.IBTransaction2;

Правилно так будет?


 
Sanya_BBB   (2006-10-10 13:32) [5]

Блин ошибся вот так будет :

перед добавлением данных присвоить компоненту  Query1 вторую транзакцию:

datamodule2.IBQuery1.Transaction:=datamodule2.IBTransaction2;
datamodule2.IBTransaction2.start;
datamodule2.IBQuery1.SQL.Clear;
datamodule2.IBQuery1.SQL.Add("insert into access_table(user_fio, user_pass, user_role) values("+fio+","+pass+", "+role+")");
datamodule2.IBQuery1.Open ;
datamodule2.IBTransaction2.commit;

А потом опять присвоить первую транзакцию:

datamodule2.IBQuery1.Transaction:=datamodule2.IBTransaction1;


 
Sergey13 ©   (2006-10-10 13:36) [6]

> Правилно так будет?

Правильно будет почитать то, на что тебе дали ссылку. Еще можно Ф1 нажать.


 
Sanya_BBB   (2006-10-10 13:57) [7]

На самом деле просто физически нет времени читать, завтра уже надо сдавать базу. Если можно по делу пожалуйста.


 
MsGuns ©   (2006-10-10 14:00) [8]

Читать про свойства и методы TIBDataBase, TIBTransaction, TIBDataSet, TIBQuery до посинения. А также "Мир интербэйз" Вострикова&Ковязина


 
MsGuns ©   (2006-10-10 14:02) [9]

>Sanya_BBB   (10.10.06 13:57) [7]
На самом деле просто физически нет времени читать, завтра уже надо сдавать базу.

Прав нет, водить авто не умею, а ехать НАДО ! Торжество воинствующего дилетантизма
Ветку ф топку


 
Sergey13 ©   (2006-10-10 14:07) [10]

> [7] Sanya_BBB   (10.10.06 13:57)

С времени, когда тебе дали ссылку полсуток прошло. А там читать 10 минут.
А времени, пересказывать тебе содержание ссылки и хелпа в краткой форме у меня катастрофически не хватает. У меня пасьянс не сходится.


 
YurikGL ©   (2006-10-10 19:09) [11]


> Почему при Commit"e транзакции, свойства Active  у всех
> компонентов  IBQuery становятся False?

Delphi syntax:

procedure CommitRetaining;

C++ syntax:

void __fastcall CommitRetaining(void)

Description

Call CommitRetaining to permanently store to the database server all updates, insertions, and deletions of data associated with the current transaction and then retain the transaction context. The current transaction is the last transaction started by calling StartTransaction.



Страницы: 1 вся ветка

Текущий архив: 2006.12.17;
Скачать: CL | DM;

Наверх




Память: 0.5 MB
Время: 0.036 c
11-1140178861
EREMA
2006-02-17 15:21
2006.12.17
Borland Developers Studio


2-1164699502
Novik
2006-11-28 10:38
2006.12.17
TMemo в DLL


15-1164602002
Думкин
2006-11-27 07:33
2006.12.17
Имидж России, Сибири.


15-1164412136
Alex Konshin
2006-11-25 02:48
2006.12.17
Хорошее интервью американца о России


2-1164714401
kan
2006-11-28 14:46
2006.12.17
Что-то не получается запрос SQL