Экспертная система Delphi.int.ru

Сообщество программистов
Общение, помощь, обмен опытом

Логин:
Пароль:
Регистрация | Забыли пароль?

Delphi.int.ru Expert

Другие разделы портала

Переход к вопросу:

#   

Статистика за сегодня:  


Лучшие эксперты

Подробнее »



Вопрос # 5 383

/ вопрос решён /

Приветствую, уважаемые эксперты!
Подскажите что надо исправить! Удаляю таблицу из списка комбобокс, таблица удаляется, но все равно она остается в списке комбобокса, если закрываю форму , а потом снова захожу на неё , то естественно её нету в списке.Пытался очищать комбобокс, а потом сразу заполнить но че то не получается. Вот код, что исправить???

 
procedure TForm2.sButton4Click(Sender: TObject);
  var
 x: TStrings;
 i: integer;
begin
 ADOCommand2.CommandText:='DROP TABLE ' +sComboBox2.Items[sComboBox2.ItemIndex];
 ADOCommand2.Execute;
  begin
ShowMessage('Группа ' +sComboBox2.Text + ' удалена из базы данных');
   exit;
begin
scombobox2.ClearSelection;
scombobox2.Clear;
begin
 x:=TstringList.Create;
 ADOConnection3.GetTableNames(x,false);
 for i := 0 to x.Count - 1 do
 begin
   sComboBox2.Items.Add(x.Strings[i]);
 end;
 sComboBox2.ItemIndex:=-1;
 x.Free;
end;
end;
 end;
  end;

Анучин Вопрос решён, но можно продолжить его обсуждение в мини-форуме

Вопрос задал: Анучин (статус: Посетитель)
Вопрос отправлен: 7 июня 2011, 03:56
Состояние вопроса: решён, ответов: 1.

Ответ #1. Отвечает эксперт: min@y™

Совершенно кривой индусский код! Хотя, я и покруче видал. Отформатированный он выглядит вот так:

procedure TForm2.sButton4Click(Sender: TObject);
var
  x: TStrings;
  i: integer;
begin
  ADOCommand2.CommandText:='DROP TABLE ' +sComboBox2.Items[sComboBox2.ItemIndex];
  ADOCommand2.Execute;
 
  begin // <--- нахрена?
    ShowMessage('Группа ' +sComboBox2.Text + ' удалена из базы данных');
    exit; // <--- советую почитать хэлп по этому оператору!
 
    begin // <--- нахрена?
      scombobox2.ClearSelection;
      scombobox2.Clear;
 
      begin // <--- нахрена?
        x:=TstringList.Create;
        ADOConnection3.GetTableNames(x,false);
 
        for i := 0 to x.Count - 1 do
          begin // <--- нахрена?
            sComboBox2.Items.Add(x.Strings[i]);
          end;  // <--- нахрена?
 
        sComboBox2.ItemIndex:=-1;
        x.Free;
      end; // <--- нахрена?
    end; // <--- нахрена?
  end; // <--- нахрена?
end;
Ну, а если переделать по-человечески, то примерно так:
procedure TForm2.sButton4Click(Sender: TObject);
begin
  ADOCommand2.CommandText:='DROP TABLE ' +sComboBox2.Items[sComboBox2.ItemIndex];
  ADOCommand2.Execute;
  ShowMessage('Группа ' +sComboBox2.Text + ' удалена из базы данных');
  ADOConnection3.GetTableNames(sComboBox2.Items, false);
end;
З.Ы. Ахтунг! Код не отлаживал, возможны баги!

Ответ отправил: min@y™ (статус: Доктор наук)
Время отправки: 7 июня 2011, 09:40
Оценка за ответ: 5

Комментарий к оценке: Спасибо, дёйствительно ваш код покрасивее будет, да и еще работает)))

Мини-форум вопроса

Всего сообщений: 0.

7 июня 2011, 18:01: Статус вопроса изменён на решённый (изменил автор вопроса — Анучин)

Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте.

Версия движка: 2.6+ (26.01.2011)
Текущее время: 22 февраля 2025, 11:26
Выполнено за 0.03 сек.