Михаиллл
Михаиллл10. Dezember 2018 08:42

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

PostgreSQL, Qt

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

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

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

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

15
Evgenii Legotckoi
  • 10. Dezember 2018 13:15

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

\dt

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

    Михаиллл
    • 11. Dezember 2018 03:12

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

      Evgenii Legotckoi
      • 11. Dezember 2018 03:16

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

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

        Михаиллл
        • 11. Dezember 2018 03:30
        • (bearbeitet)

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

          Evgenii Legotckoi
          • 11. Dezember 2018 03:42

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

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

            Михаиллл
            • 11. Dezember 2018 03:44

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

              Evgenii Legotckoi
              • 11. Dezember 2018 03: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. Dezember 2018 05:27

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

                  Evgenii Legotckoi
                  • 11. Dezember 2018 05:54

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

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

                    Михаиллл
                    • 11. Dezember 2018 06:36

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

                      Evgenii Legotckoi
                      • 11. Dezember 2018 07:45

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

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

                      QSqlError::ErrorType QSqlError::type() const
                      
                        Михаиллл
                        • 11. Dezember 2018 08: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. Dezember 2018 09:23
                          • (bearbeitet)

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

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

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

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

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

                            Михаиллл
                            • 11. Dezember 2018 11:00

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

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

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

                              Михаиллл
                              • 12. Dezember 2018 12:52

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

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

                                Kommentare

                                Nur autorisierte Benutzer können Kommentare posten.
                                Bitte Anmelden oder Registrieren
                                Letzte Kommentare
                                A
                                ALO1ZE19. Oktober 2024 15:19
                                Fb3-Dateileser auf Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                                ИМ
                                Игорь Максимов5. Oktober 2024 14:51
                                Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                                d
                                dblas55. Juli 2024 18:02
                                QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                                k
                                kmssr9. Februar 2024 02:43
                                Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                                Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                                Jetzt im Forum diskutieren
                                J
                                JacobFib17. Oktober 2024 10:27
                                добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
                                JW
                                Jhon Wick1. Oktober 2024 22:52
                                Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
                                КГ
                                Кирилл Гусарев27. September 2024 16:09
                                Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
                                F
                                Fynjy22. Juli 2024 11:15
                                при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

                                Folgen Sie uns in sozialen Netzwerken