Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
20 / 19 / 3
Регистрация: 23.09.2014
Сообщений: 285

Библиотека "Medoo" - как проверить существует ли таблица?

03.01.2019, 23:14. Показов 1252. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Вот так не работает

PHP
1
2
3
4
5
if ($db->query("SHOW TABLES LIKE table_name")) {
    echo "table_name существует";
} else {
    echo "table_name НЕ существует";
}
пишет что существует, равно как и так

PHP
1
if ($db->query("DESCRIBE `table_name`")) {
результат один и тот-же, существует ли таблица или нет
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
03.01.2019, 23:14
Ответы с готовыми решениями:

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

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

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

11
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,904
04.01.2019, 15:52
С Medoo не работал, но судя по документации
https://medoo.in/api/query
метод query возвращает объект PDOStatement
http://php.net/manual/ru/class.pdostatement.php
у которого есть методы fetch, fetchAll и т.д.
0
20 / 19 / 3
Регистрация: 23.09.2014
Сообщений: 285
04.01.2019, 16:19  [ТС]
Цитата Сообщение от Jodah Посмотреть сообщение
...у которого есть методы fetch, fetchAll и т.д.
а если таблица существует но пуста?
0
1304 / 996 / 232
Регистрация: 01.10.2018
Сообщений: 3,869
04.01.2019, 16:39
Смотрите, как от этого меняются возвращаемые значения, и делайте нужные проверки.
0
20 / 19 / 3
Регистрация: 23.09.2014
Сообщений: 285
04.01.2019, 17:04  [ТС]
Через SELECT можно проверить таблицу но если в ней есть хотя-бы одна запись

PHP
1
2
3
4
5
if ($db->query("SELECT * FROM table_name LIMIT 1")->fetch() != Array()) {
    echo $prefiks."_users существует";
} else {
    echo $prefiks."_users НЕ существует";
}
но на пустую реакция не верная
0
1304 / 996 / 232
Регистрация: 01.10.2018
Сообщений: 3,869
04.01.2019, 17:31
Цитата Сообщение от Richik Посмотреть сообщение
пишет что существует
Пока что это просто запросы. Проверяйте данные из выборки.

Добавлено через 4 минуты
Цитата Сообщение от Richik Посмотреть сообщение
Через SELECT
Вот как раз-таки SELECT будет возвращать ошибку при отсутствии таблицы, если не ошибаюсь. Но этот способ обычно не используют, т.к. могут быть и другие причины ошибки.

Добавлено через 1 минуту
Цитата Сообщение от Richik Посмотреть сообщение
но на пустую реакция не верная
А тут опять-таки нужно проверять данные из выборки. Т.е. если ноль строк при запросе всех строк, то таблица пустая.

Добавлено через 57 секунд
Фактические данные можно не выбирать. Используйте COUNT() или что-то подобное.
0
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,904
04.01.2019, 18:31
Цитата Сообщение от Richik Посмотреть сообщение
а если таблица существует но пуста?
Посмотрите с помощью var_dump, что вернётся в обоих случаях.
0
20 / 19 / 3
Регистрация: 23.09.2014
Сообщений: 285
04.01.2019, 21:21  [ТС]
Цитата Сообщение от Jodah Посмотреть сообщение
var_dump
"SELECT" - если таблица пуста или не существует -
PHP
1
table_name НЕ существует bool(false)
иначе выводит массив значений первой записи

"SHOW TABLES LIKE" - всегда пишет -
PHP
1
table_name  НЕ существует bool(false)
"DESCRIBE" - всегда пишет -
PHP
1
table_name  НЕ существует bool(false)
0
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,904
04.01.2019, 21:58
Richik, это же программирование, здесь не нужно гадать. Если условие не работает как надо - проверяйте, какое значение туда подставляется.

Метод query возвращает объект, ссылку на него я дал выше. Значит надо из этого объекта вытащить результат запроса, посмотреть его содержимое с помощью var_dump и написать под полученное значение корректное условие. Именно под само значение, исходный объект PDOStatement пихать в условие не нужно.
0
20 / 19 / 3
Регистрация: 23.09.2014
Сообщений: 285
05.01.2019, 11:44  [ТС]
Цитата Сообщение от Jodah Посмотреть сообщение
посмотреть его содержимое с помощью var_dump
я так сделал, вроде
0
20 / 19 / 3
Регистрация: 23.09.2014
Сообщений: 285
06.01.2019, 18:03  [ТС]
Кажется нашел решение, через метод Count

PHP
1
2
3
4
5
6
7
8
9
 $res = $db->count('table_name');
 
if (gettype($res) == 'integer' & $res == 0){
    echo 'Таблица пуста';
}elseif (gettype($res) == 'integer' & $res > 0){
    echo 'Количество записей в таблице: '.$res;
}elseif (gettype($res) == 'boolean'){
    echo 'Таблица не существует';
}
Если таблица существует и пуста, то результатом будет Таблица пуста
Если таблица существует имеет записи, то будет отображено количество записей
Если таблицы нет,то "Таблица не существует"
0
20 / 19 / 3
Регистрация: 23.09.2014
Сообщений: 285
08.01.2019, 23:31  [ТС]
Вот что пишет админ по этому вопросу:
If you want to check table existence, you can run this query with API query(). https://medoo.in/api/query

PHP
1
SHOW TABLES FROM XXXX
к сожалению способ не рабочий

делаю вот так:
PHP
1
2
3
4
5
6
7
8
9
    
    $dbname = 'dbtest';
    
    $table = $db->query('SHOW TABLES FROM '.$dbname);
    echo gettype($table);
    echo '<br />';
    print_r($table);
    echo '<br />';
    var_dump($table);
Результат:
object
PDOStatement Object ( [queryString] => SHOW TABLES FROM dbtest)
object(PDOStatement)#5 (1) { ["queryString"]=> string(23) "SHOW TABLES FROM dbtest" }
может я делаю что-то не правильно?

Добавлено через 17 минут
Все, разобрался
PHP
1
$table = $db->query('SHOW TABLES')->fetchAll();
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.01.2019, 23:31
Помогаю со студенческими работами здесь

Библиотека Medoo поиск подстроки в запросе (аналог strpos). WHERE Syntax
Подскажете пожалуйста как в строке (из базы) найти подстроку. Т.е. я выполнять запрос, и в боке WHERE необходим эквивалент strpos Ну...

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

Проверить, существует ли таблица в БД
Добрый день. Подскажите пожалуйста как можно проверить существует ли таблица в БД?

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

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


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
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