Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.72/47: Рейтинг темы: голосов - 47, средняя оценка - 4.72
36 / 32 / 23
Регистрация: 28.12.2015
Сообщений: 264

Проверить, существует ли таблица в БД

15.06.2016, 11:29. Показов 8780. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день. Подскажите пожалуйста как можно проверить существует ли таблица в БД?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
15.06.2016, 11:29
Ответы с готовыми решениями:

Проверить существует ли таблица
Добавить запись в таблицу, предворительно проверив есть ли такая таблица, если нету- то создаать ее и добавить запись. MySQL $db =...

Проверить существует ли таблица с таким именем access
Привет, как можно осуществить проверку существует ли таблица с таким именем в access через delphi ?

Как проверить существует ли таблица в базе данных?
Всем привет! Я создал таблицу следующим кодом: @mysql_query("CREATE TABLE Tab(fio TEXT,Mail TEXT,Birthday DATE,Reg INT,Stat...

14
77 / 77 / 42
Регистрация: 30.09.2014
Сообщений: 342
15.06.2016, 12:14
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
 private void button2_Click(object sender, EventArgs e)
        {
 
            try
            {
                string NameTable = textBox1.Text;
 
                NameTable = "SELECT * FROM " + NameTable;
 
                string connectionString = Properties.Settings.Default.ConnectionString;
 
                SqlConnection connection = new SqlConnection(connectionString);
                connection.Open();
 
                // посылаем запрос comand к БД ...результат в dr
                SqlCommand command1 = new SqlCommand(NameTable, connection);
                SqlDataReader dr1 = command1.ExecuteReader();
 
 
 
                dr1.Close();
 
                MessageBox.Show("Существует");
                         connection.Close();
            }
 
            catch
            {
                MessageBox.Show(" НЕ cуществует");
 
            }
 
   
 
 
        }
3
Хитрая блондиночка $)
 Аватар для Hikari
1472 / 988 / 399
Регистрация: 21.12.2015
Сообщений: 3,785
15.06.2016, 12:19
А я бы лучше обратилась к чему-то более пригодному для таких проверок. Например в MS SQL это системная табличка.
Запрос выглядит примерно так:
SQL
1
SELECT COUNT(*) FROM sys.sysobjects WHERE name=<Имя искомой таблицы>
Если вернет 0 - значит нет такой.
В других СУБД тоже есть подобные системные таблицы, рекомендую работать с ними, а не ловить исключения.
1
77 / 77 / 42
Регистрация: 30.09.2014
Сообщений: 342
15.06.2016, 12:21
Даже лучше catch такой написать

catch(SqlException)
{
MessageBox.Show("Не существует");

}

Добавлено через 1 минуту
Согласен
1
Хитрая блондиночка $)
 Аватар для Hikari
1472 / 988 / 399
Регистрация: 21.12.2015
Сообщений: 3,785
15.06.2016, 13:44
Цитата Сообщение от OTT Посмотреть сообщение
Даже лучше catch такой написать
Такая конструкция будет ловить все ошибки, а не только исключение отсутствия объекта. Это может плохо сказаться.
0
 Аватар для Пaтрик
442 / 410 / 132
Регистрация: 21.01.2012
Сообщений: 976
15.06.2016, 17:58
Цитата Сообщение от Hikari Посмотреть сообщение
T-SQL
1
SELECT COUNT(*) FROM sys.sysobjects WHERE name=<Имя искомой таблицы>
sys.objects - это вьюшка, которая отдает все объекты, т.е. если ввести название индекса, то он его тоже посчитает.
Поэтому лучше использовать sys.tables и COUNT скастовать в BIT, таким образом получим булевый флажок:
T-SQL
1
2
3
SELECT CONVERT(BIT, COUNT(*))
FROM sys.tables
WHERE name = N'<Имя искомой таблицы>'
1
Хитрая блондиночка $)
 Аватар для Hikari
1472 / 988 / 399
Регистрация: 21.12.2015
Сообщений: 3,785
15.06.2016, 18:54
Цитата Сообщение от Пaтрик Посмотреть сообщение
Поэтому лучше использовать sys.tables и COUNT скастовать в BIT
Ну не спорю. Хотя по-моему называть индекс таким же именем как и таблица СУБД не даст.
Или даст?
0
 Аватар для Пaтрик
442 / 410 / 132
Регистрация: 21.01.2012
Сообщений: 976
15.06.2016, 18:55
Ну не даст, просто сам пользователь может ввести название таблицы по типу "IDX_Person_Id"
0
36 / 32 / 23
Регистрация: 28.12.2015
Сообщений: 264
15.06.2016, 19:04  [ТС]
Спасибо за ответы, но в MySQL не селен, поэтому за одним вопросом возникает другой

Вот так пытаюсь отправить запрос:
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
using (MySqlConnection con = new MySqlConnection("Server=xxxxxx;Port=xxxxxx;Database=xxxxxx;Uid=xxxxxx;Pwd=xxxxxx;"))
{
    try
    {
        con.Open();
        MySqlCommand Query = new MySqlCommand();
        Query.Connection = con;
        Query.CommandText = "SELECT CONVERT(BIT, COUNT(*)) FROM sys.tables WHERE name = N'proverka'";
        Query.ExecuteNonQuery();
    }
    catch (Exception ex)
    {
        MessageBox.Show(ex.Message);
    }
}
Как исходя из этого кода, если он, конечно, верен, сделать условие? (if(....)
0
 Аватар для Пaтрик
442 / 410 / 132
Регистрация: 21.01.2012
Сообщений: 976
15.06.2016, 19:07
Выше указанные примеры приводились для MS SQL Server. Для MySQL будут другие запросы.
0
36 / 32 / 23
Регистрация: 28.12.2015
Сообщений: 264
15.06.2016, 19:08  [ТС]
Аааа, вон оно что...

Как быть тогда? Единственный способ ловить исключения как показал OTT?
0
 Аватар для Пaтрик
442 / 410 / 132
Регистрация: 21.01.2012
Сообщений: 976
15.06.2016, 19:17
Нет, нужно сделать аналогичный запрос для MySQL.
0
Хитрая блондиночка $)
 Аватар для Hikari
1472 / 988 / 399
Регистрация: 21.12.2015
Сообщений: 3,785
15.06.2016, 20:16
Цитата Сообщение от Пaтрик Посмотреть сообщение
просто сам пользователь может
А вот это верно подмечено
0
 Аватар для Пaтрик
442 / 410 / 132
Регистрация: 21.01.2012
Сообщений: 976
15.06.2016, 20:57
Для MySQL
MySQL
1
2
3
4
select count(*)
from information_schema.tables
where table_type = 'BASE TABLE' and 
  table_name = '<название таблицы>'
1
36 / 32 / 23
Регистрация: 28.12.2015
Сообщений: 264
16.06.2016, 08:49  [ТС]
Спасибо за ответы, буду пробовать.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
16.06.2016, 08:49
Помогаю со студенческими работами здесь

Как проверить, существует ли уже таблица с заданным именем?
Заранее Спасибо за ответ.

Как проверить, существует ли уже таблица с заданным именем? в ADO
Как проверить, существует ли уже таблица с заданным именем? в ADO

В определенный момент отработки программы мне нужно проверить существует ли на сервере определенная временная таблица
Добрый всем день!!!! У меня следующая проблема. В определенный момент отработки программы мне нужно проверить существует ли на сервере...

Библиотека "Medoo" - как проверить существует ли таблица?
Вот так не работает if ($db-&gt;query(&quot;SHOW TABLES LIKE table_name&quot;)) { echo &quot;table_name существует&quot;; } else { echo...

Проверить, существует ли каталог, и если не существует - создать
Как средствами VB6 проверить существует ли каталог, и если не существует - создать? DName$ = &quot;C:\111&quot; If Dir(DName$) &lt;&gt;...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru