Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 06.07.2013, 19:20
Zhigalov Zhigalov вне форума
Начинающий
 
Регистрация: 27.05.2009
Сообщения: 100
Репутация: -1277
По умолчанию Сравнение

Суть такова есть 7 Edit'ов в них ввожу название таблиц в БД. Data_1...7. Как
мне сравнить то что я ввел в Edit'ы с существующими в БД таблицами. То есть я ввел в какой не то Edit не существующую таблицу и мне бы выдало сообщение что таблицы такой в БД не существует. БД MSSQL2005.
Ответить с цитированием
  #2  
Старый 06.07.2013, 20:34
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,036
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Цитата:
Сообщение от Zhigalov
Суть такова есть 7 Edit'ов в них ввожу название таблиц в БД. Data_1...7. Как
мне сравнить то что я ввел в Edit'ы с существующими в БД таблицами. То есть я ввел в какой не то Edit не существующую таблицу и мне бы выдало сообщение что таблицы такой в БД не существует. БД MSSQL2005.

Варианты:
1. Разобраться с метадатой. У сервера можно спросить какие табицы есть в БД (http://blog.sqlauthority.com/2007/06...-of-database/).
2. Просто попробовать сделать простенький запрос в соотв. табличку, типа:
Код:
 
select 1 from tablename where 1=2
Если получилось, то таблица есть, если ошибка - то нету или другая проблема (с подключением).

ЗЫ. Еще один забаненный в гугле
Ответить с цитированием
  #3  
Старый 06.07.2013, 20:42
Zhigalov Zhigalov вне форума
Начинающий
 
Регистрация: 27.05.2009
Сообщения: 100
Репутация: -1277
По умолчанию

Цитата:
Сообщение от lmikle
Варианты:
1. Разобраться с метадатой. У сервера можно спросить какие табицы есть в БД (http://blog.sqlauthority.com/2007/06...-of-database/).
2. Просто попробовать сделать простенький запрос в соотв. табличку, типа:
Код:
 
select 1 from tablename where 1=2
Если получилось, то таблица есть, если ошибка - то нету или другая проблема (с подключением).

ЗЫ. Еще один забаненный в гугле

Я вот так вот планирую.
Код:
AdoQuery1.SQL.Text:='select 1 from tablename where 1=2';
А как узнать то выполнился или не выполнился?
Чтоб
Код:
ShowMessage('Таблицы не существует');

Последний раз редактировалось Zhigalov, 06.07.2013 в 20:46.
Ответить с цитированием
  #4  
Старый 06.07.2013, 20:56
Аватар для M.A.D.M.A.N.
M.A.D.M.A.N. M.A.D.M.A.N. вне форума
Sir Richard Abramson
 
Регистрация: 05.04.2008
Сообщения: 5,505
Версия Delphi: XE10
Репутация: выкл
По умолчанию

База какая? В путевых базах есть вьюшка, которая позволяет вытащить перечень пользовательских таблиц.
__________________
— Как тебя понимать?
— Понимать меня не обязательно. Обязательно меня любить и кормить вовремя.


На Delphi, увы, больше не программирую.
Рекомендуемая литература по программированию
Ответить с цитированием
  #5  
Старый 08.07.2013, 08:55
Zhigalov Zhigalov вне форума
Начинающий
 
Регистрация: 27.05.2009
Сообщения: 100
Репутация: -1277
По умолчанию

Цитата:
Сообщение от M.A.D.M.A.N.
База какая? В путевых базах есть вьюшка, которая позволяет вытащить перечень пользовательских таблиц.
Ну вытащу я список таблиц, их там 21 одна штука, а мне из них только семь надо. Как мне их там выискивать то? Они там в совершенно рандомном порядке меняются.
Мне кажется проще всего, как тут предложили сделать запросом.
Только я вот не как не могу сообразить как проверить то выполнился он или нет(То есть если запрос успешный то все хорошо едем дальше, а ежели нет то пишем сообщение ). В принципе если такой таблицы нет, Delphi выдает "Invalid object name 'dbName'''. Но все таки хотелось бы чтоб на нашем языке было и понятно пользователю.
Ответить с цитированием
  #6  
Старый 08.07.2013, 11:02
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Ну можно ведь вообще просто поступить. Считываете имена таблиц в стринглист и проверяете ваше введенное в едите имя на наличие в стринглисте через его метод инексоф. И всех делов.
Код:
procedure TForm2.Button1Click(Sender: TObject);
Var
  SL: TStringList;
begin
 if not AdoConnection1.Connected then Exit;
 SL := TStringList.Create;
 AdoConnection1.GetTableNames(SL);
 if SL.IndexOf(Edit1.Text) = -1
 then ShowMessage('Нетути такой табли');
 SL.Free;
end;
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.

Последний раз редактировалось Страдалецъ, 08.07.2013 в 11:11.
Ответить с цитированием
Этот пользователь сказал Спасибо Страдалецъ за это полезное сообщение:
Zhigalov (08.07.2013)
  #7  
Старый 08.07.2013, 13:33
Zhigalov Zhigalov вне форума
Начинающий
 
Регистрация: 27.05.2009
Сообщения: 100
Репутация: -1277
По умолчанию

Цитата:
Сообщение от Страдалецъ
Ну можно ведь вообще просто поступить. Считываете имена таблиц в стринглист и проверяете ваше введенное в едите имя на наличие в стринглисте через его метод инексоф. И всех делов.
Код:
procedure TForm2.Button1Click(Sender: TObject);
Var
  SL: TStringList;
begin
 if not AdoConnection1.Connected then Exit;
 SL := TStringList.Create;
 AdoConnection1.GetTableNames(SL);
 if SL.IndexOf(Edit1.Text) = -1
 then ShowMessage('Нетути такой табли');
 SL.Free;
end;

Даже и не задумался чтоб так сделать. Сделал вот так вот. Сейчас видимо переделаю.
Код:
...
 try
 DataModule2.Query.Open;
 except
  on EOleException do  MessageDlg('Некорректные настройки.'+
    ''+#13#10+''+Form3.Edit1.Text+' не существует!!!', mtError, [mbCancel], 0);
 end;
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 05:23.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter