Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Запрос на проверку существования таблицы, Как его написать? 
V
    Опции темы
kulikoff
Дата 24.10.2006, 09:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 334
Регистрация: 5.11.2005
Где: Киев

Репутация: 1
Всего: 1



Собственно, сабж. СУБД ORACLE 8, надо написать запрос, который будет возвращать инфу существует ли таблица...
PM MAIL WWW ICQ Skype   Вверх
Akella
Дата 24.10.2006, 09:29 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

Репутация: 29
Всего: 329



можно попробовать сделать выборку из таблицы в модуле tray except

Код

Function TableExsist...
try
  query.sql.add('select id from table where id = -999');
  result := true;
except
  result := false;
end;
...

пользователь не увидит ошибку

Я не в курсе, как в ORACLE добраться до системных таблиц, если таковые есть. Я тебе дал один из вариантов. Уверен, чтьо это не единственный.

Добавлено @ 09:39 
Код

//так
select count(*) from user_tables where table_name = 'TABLENAME';
//или так
select count(*) from all_tables where table_name = 'TABLENAME'; 

PM MAIL   Вверх
Vas
Дата 24.10.2006, 09:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 830
Регистрация: 29.6.2005
Где: Stavropol region

Репутация: 23
Всего: 28



Код

select table_name from user_tables where table_name='ИМЯ ТАБЛИЦЫ' //проверка существует и доступна ли пользователю (находится в его схеме)

select table_name from all_tables where table_name='ИМЯ ТАБЛИЦЫ' //проверка существует и доступна ли пользователю (находится вне его схемы)

select table_name from dba_tables where table_name='ИМЯ ТАБЛИЦЫ' //проверка существует и доступна ли пользователю (это только для DBA)



--------------------
И опыт, сын ошибок трудных, И гений, парадоксов друг, И случай, бог изобретатель. ... (А.С. Пушкин)
PM MAIL   Вверх
smartov
Дата 24.10.2006, 09:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


свой собственный
****


Профиль
Группа: Экс. модератор
Сообщений: 4225
Регистрация: 2.2.2006
Где: NJ

Репутация: нет
Всего: 259



Код

try    
  query.sql.add('mysql drop table tableName');    
  ShowMessage('Таблица существовала');
except    
....
end;

 smile  smile 

А если серъёзно то можно еще
Код

select * from user_objects where object_type = 'TABLE';

PM MAIL   Вверх
kulikoff
Дата 24.10.2006, 11:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 334
Регистрация: 5.11.2005
Где: Киев

Репутация: 1
Всего: 1



Спасибо!
PM MAIL WWW ICQ Skype   Вверх
Rodman
Дата 24.10.2006, 13:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 22
Всего: 122



smartov, конечно проверка боем (удалением) прикольно...

Но может и мой пример подойдет...
PM MAIL WWW Skype GTalk YIM MSN   Вверх
DDX
Дата 30.10.2006, 17:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 127
Регистрация: 31.1.2005
Где: Москва

Репутация: 5
Всего: 5



можно ещё загнать список таблиц БД в StringList функцией GetTablesNames адоконнекшена и в нем уже поискать нужную..

-- added -- ага, RodMan то же самое показал

Это сообщение отредактировал(а) DDX - 30.10.2006, 17:13
--------------------
Учиться, учитьcя и ещё раз учиться  
PM MAIL WWW   Вверх
Rodman
Дата 31.10.2006, 11:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 22
Всего: 122



DDX,  smile 
PM MAIL WWW Skype GTalk YIM MSN   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Базы данных и репортинг"
Vit
Петрович

Запрещено:

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами


Обязательно указание:

1. Базы данных (Paradox, Oracle и т.п.)

2. Способа доступа (ADO, BDE и т.д.)


  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи
  • Вопросы по SQL и вопросы по базам данных не связанные с Дельфи задавать здесь

FAQ раздела лежит здесь!


Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Vit, Петрович.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: Базы данных и репортинг | Следующая тема »


 




[ Время генерации скрипта: 0.1246 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.