1. Транзакция нужна для любого обращения к базе. Если select нужен для отображения (просмотра) данных, то транзакцию нужно закрывать когда эти данные видеть уже не надо. Порекомендовал бы использовать вместо ibquery ibdataset. Но это уже как хош. Если в компонентах все параметры установлены (принадлежность к базе и привязка к транзакции), то транзакция сама стартанет, соответственно лучше будет так:
Код:
sql.Close; // тут лучше с if...then
sql.SQL.Clear;
sql.SQL.text:='SELECT * FROM LOGIN';
sql.Open;
когда, например, пользователь закрывает окно, тут уже закрываем транзакцию:
Код:
sql.Transaction.Active:=False;
далее:
Код:
sql.SQL.text:='INSERT INTO LOGIN (ACCOUNT) VALUES (NEWACCAUNT)';
sql.ExecSQL; // выполняешь sql
sql.Transaction.Commit;// тут ты передаешь изменения в базу
после commit все select будут показывать изменения, если конечно они не остались в рамках транзакции запущенной до внесения изменений.
2. В интербейзе чтоб получить такую ошибку надо оч сильно постараться. Но на всякий случай, постарайся не открывать транзакцию, пока пользователь не внесет все данные. Другими словами, сокращай до минимума время жизни транзакции.
3. Каких- то особых св-в там нет, ИМХО полезным будет только defaultaction