Михаиллл
Михаиллл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 г. 13: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:00

                            врятли, иначе бы в описании ошибки не появились название 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 г. 11:37

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

                                • Результат:80баллов,
                                • Очки рейтинга4
                                m
                                • molni99
                                • 26 октября 2024 г. 11:29

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

                                • Результат:20баллов,
                                • Очки рейтинга-10
                                Последние комментарии
                                i
                                innorwall15 ноября 2024 г. 8:26
                                Qt/C++ - Урок 031. QCustomPlot - строим график по времени buy generic priligy We can just chat, and we will not lose too much time anyway
                                i
                                innorwall15 ноября 2024 г. 6:03
                                Qt/C++ - Урок 060. Настройка внешнего вида приложения в рантайме I didnt have an issue work colors priligy dapoxetine 60mg revia cost uk August 3, 2022 Reply
                                i
                                innorwall14 ноября 2024 г. 22:42
                                Как Копировать Файлы в Linux If only females relatives with DZ offspring were considered these percentages were 23 order priligy online uk
                                i
                                innorwall14 ноября 2024 г. 20:09
                                Qt/C++ - Урок 068. Hello World с использованием системы сборки CMAKE в CLion ditropan pristiq dosing With the Yankees leading, 4 3, Rivera jogged in from the bullpen to a standing ovation as he prepared for his final appearance in Chicago buy priligy pakistan
                                Сейчас обсуждают на форуме
                                i
                                innorwall14 ноября 2024 г. 14:39
                                добавить qlineseries в функции priligy amazon canada 93 GREB1 protein GREB1 AB011147 6
                                i
                                innorwall11 ноября 2024 г. 21:55
                                Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
                                9
                                9Anonim25 октября 2024 г. 19:10
                                Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
                                ИМ
                                Игорь Максимов3 октября 2024 г. 14:05
                                Реализация навигации по разделам Спасибо Евгений!

                                Следите за нами в социальных сетях