Михаиллл
МихаилллЖел. 10, 2018, 8:42 Т.Ж.

При подключении к PostgreSQL не удается открыть таблицу

PostgreSQL, Qt

Добрый день.
Я подключился к базе PostgreSQL.
Пытаюсь подключиться к таблице

QSqlTableModel *SearchTableModel = new QSqlTableModel(this);
SearchTableModel->setTable("ResumePostgresSQL");
SearchTableModel->select();

но выдает ошибку:
QSqlError("", "Unable to find table ResumePostgresSQL", "")
при этом эта таблица у меня точно есть.
Скажите пожалуйста, как подключиться к этой таблице

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!

15
Evgenii Legotckoi
  • Жел. 10, 2018, 1:15 Т.Қ.

Зайдите в консоль программы psql и посмотрите список таблиц с помощью следующей команды

\dt

Ну и ещё один момент. А соединение с базой данных в данный момент активно? Мало ли, вызов таблицы происходит раньше, чем следовал бы.

    Михаиллл
    • Жел. 11, 2018, 3:12 Т.Ж.

    Но я в редакторе посмотрел, база с таблицей точно есть и в ней хранится тестовая информация.
    У меня стоит несколько версийPSQL. С 11 версии таблица считывается, а с 9,6 и 10 нет.
    И как оказалось HostName указывать не нужно и без него открывается.

      Evgenii Legotckoi
      • Жел. 11, 2018, 3:16 Т.Ж.

      Ну это у вас считывается без хоста потому, что установка локальная. Если база данных будет крутиться на другом компьютере, то ничего считываться не будет.

      А по поводу версий 9,6, 10, 11 ничего удивительного, если у вас все три одновременно установлены. Один порт может слушать только одно приложение PostgreSQL. У них же у всех один и тот же порт. Только одно приложение может слушать порт. Соответственно только одно и отвечает. А остальные скорее всего даже и не запустились.

        Михаиллл
        • Жел. 11, 2018, 3:30 Т.Ж.
        • (өңделген)

        Но у них разные порты: 5435, 5434, 5433, 5432

          Evgenii Legotckoi
          • Жел. 11, 2018, 3:42 Т.Ж.

          Вообще нормально идёт только порт 5432. Не знаю, может быть при установке нескольких приложений и занятости одного порта там автоматически устанавливается другой. Может быть.

          Вообще, в чём проблема, если у вас одна из версий работает? В нормальном режиме никто не использует несколько версий приложения базы данных. В этом особо смысла нет. Каждое приложение PostgreSQL может хранить в себе сколько угодно баз данных.

            Михаиллл
            • Жел. 11, 2018, 3:44 Т.Ж.

            Проблема с переносом базы данных. В 11 версии не меняется таблспэйс. Иначе как базу прикрепить к приложению и перенести на другой комп?

              Evgenii Legotckoi
              • Жел. 11, 2018, 3:49 Т.Ж.

              Я правильно понимаю, что вот на такое в интеренте вы уже наталкивались?

              I assume that your tablespace name is tblspc.

              1. Get Oid of your tablespace
              test=# SELECT oid,spcname FROM pg_tablespace WHERE spcname = 'tblspc';
                oid  | spcname 
              -------+---------
               24580 | tblspc
              (1 row)
              
              1. Stop postgres
              $ pg_ctl -D $PGDATA stop
              
              1. Move directory from old one to new one
              $ mv /old/dir /new/dir
              

              or

              $ cp -r /old/dir /new/dir
              $ rm -rf /old/dir
              
              1. Change tablespace's link to new directory
              $ cd $PGDATA/pg_tblspc
              $ rm 24580
              $ ln -s /new/dir 24580
              
              1. Start postgres
              $ pg_ctl -D $PGDATA start
              

              Then, you can see the tablespace's directory has changed.

              test=# SELECT pg_tablespace_location(24580);
               pg_tablespace_location
              ------------------------
               /new/dir
              (1 row)
              
                Михаиллл
                • Жел. 11, 2018, 5:27 Т.Ж.

                Нет, не доводилось. Как думаете, дело может быть в порте? Если все удалить и установить 9,6 в порт 5432, выше шанс что база заработает?

                  Evgenii Legotckoi
                  • Жел. 11, 2018, 5:54 Т.Ж.

                  Не знаю, что вы имеете ввиду под удалить всё, но попробовать хотя бы порт установить на 5432 стоит.

                  вы смотрели номера портов в какой-то конфигурации? Или как-то иначе?

                    Михаиллл
                    • Жел. 11, 2018, 6:36 Т.Ж.

                    да, они отображаются возле базы.
                    Удалил все лишнее, оставил 9,6.
                    Теперь порт этой версии 5432.
                    Тем не менее все та же ошибка

                      Evgenii Legotckoi
                      • Жел. 11, 2018, 7:45 Т.Ж.

                      Хорошо, пойдём иначе, а какой тип ошибки у той QSqlError?

                      Что возвращает этот метод?

                      QSqlError::ErrorType QSqlError::type() const
                      
                        Михаиллл
                        • Жел. 11, 2018, 8:45 Т.Ж.

                        Скажите пожалуйста, как им воспользоваться? Если его записать в qDebug()<<, то выдает ошибку компиляции.
                        Также заметил если бд и таблица состоит из цифр то выдает ошибку :
                        QSqlError("42601", "QPSQL: Unable to create query", "ОШИБКА: ошибка синтаксиса (примерное положение: \"123\")\nLINE 1: SELECT \"id\", \"int\" FROM 123\n
                        где 123 - название таблицы
                        а если в той-же бд создана таблица с названием, состоящим не только из цифр, то выдает ошибку :
                        QSqlError("", "Unable to find table Test1", "")
                        также в первом случае даже отображается название одного из двух столбцов

                          Evgenii Legotckoi
                          • Жел. 11, 2018, 9:23 Т.Ж.
                          • (өңделген)

                          Скажите пожалуйста, как им воспользоваться? Если его записать в qDebug()<<, то выдает ошибку компиляции

                          что именно написано в ошибке?

                          ммм.. вас вообще как угораздило назвать таблицу 123 ? не надо называть таблицы только цифрами, а также наименования столбцов только цифрами.

                          В том же самом MySQL вообще в документации это запрещено. Мне лень копаться в документации PostgreSQL. Но, наверняка я найду что-то подобное.

                          Запрос скорее всего воспринимается не как имя таблице а как переменная типа int...

                            Михаиллл
                            • Жел. 11, 2018, 11 Т.Ж.

                            врятли, иначе бы в описании ошибки не появились название 2 моих столбцов.
                            и уже точно можно так называть названия баз, в 11 версии у меня как раз к такой базе вышло подключиться и получить из нее информацию.
                            но у меня есть другая таблица с названием из цифр и букв, и к ней не выходит подключиться.
                            Если пишу так:

                             qDebug()<<QSqlError::ErrorType QSqlError::type() const;
                            
                            

                            то говорит что нет скобочки:
                            D:\QTProject\ReaderResume\mainwindow.cpp:1106: ошибка: expected '(' for function-style cast or type construction

                              Михаиллл
                              • Жел. 12, 2018, 12:52 Т.Қ.

                              Оказывается оно все переводит в нижний регистр и нужно так писать:

                              SearchTableModel->setTable("\"Test2\"");
                              

                                Пікірлер

                                Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
                                Кіріңіз немесе Тіркеліңіз
                                AD

                                C++ - Тест 004. Указатели, Массивы и Циклы

                                • Нәтиже:50ұпай,
                                • Бағалау ұпайлары-4
                                m
                                • molni99
                                • Қаз. 26, 2024, 1:37 Т.Ж.

                                C++ - Тест 004. Указатели, Массивы и Циклы

                                • Нәтиже:80ұпай,
                                • Бағалау ұпайлары4
                                m
                                • molni99
                                • Қаз. 26, 2024, 1:29 Т.Ж.

                                C++ - Тест 004. Указатели, Массивы и Циклы

                                • Нәтиже:20ұпай,
                                • Бағалау ұпайлары-10
                                Соңғы пікірлер
                                ИМ
                                Игорь МаксимовҚар. 22, 2024, 11:51 Т.Ж.
                                Django - Оқулық 017. Теңшелген Django кіру беті Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
                                Evgenii Legotckoi
                                Evgenii LegotckoiҚаз. 31, 2024, 2:37 Т.Қ.
                                Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
                                A
                                ALO1ZEҚаз. 19, 2024, 8:19 Т.Ж.
                                Qt Creator көмегімен fb3 файл оқу құралы Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                                ИМ
                                Игорь МаксимовҚаз. 5, 2024, 7:51 Т.Ж.
                                Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                                d
                                dblas5Шілде 5, 2024, 11:02 Т.Ж.
                                QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                                Енді форумда талқылаңыз
                                m
                                moogoҚар. 22, 2024, 7:17 Т.Ж.
                                Mosquito Spray System Effective Mosquito Systems for Backyard | Eco-Friendly Misting Control Device & Repellent Spray - Moogo ; Upgrade your backyard with our mosquito-repellent device! Our misters conce…
                                Evgenii Legotckoi
                                Evgenii LegotckoiМаусым 24, 2024, 3:11 Т.Қ.
                                добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
                                t
                                tonypeachey1Қар. 15, 2024, 6:04 Т.Ж.
                                google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
                                NSProject
                                NSProjectМаусым 4, 2022, 3:49 Т.Ж.
                                Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…

                                Бізді әлеуметтік желілерде бақылаңыз