Михаиллл
МихаилллJan. 4, 2019, 10:49 a.m.

Как в PSQL сохранить изображение

PSQL

Здравствуйте, как в Здравствуйте, как в можно сохранить изображение?
В документации не нашел подходящего типа данных.

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Do you like it? Share on social networks!

9
Evgenii Legotckoi
  • Jan. 5, 2019, 8:07 a.m.

Добрый день!

Тип данных BLOB нужно использовать для хранения изображения в базе данных, но если честно, то это излишняя нагрузка на базу. Лучше складывать изобажения в определённый каталог, а в базе данных хранить только информацию о путях к файлам.

Вот эта статья должна вам помочь разобраться с добавлением изображения в базу данных, если ваш вопрос также косвенно касался Qt. Не смотрите, что там SQLite, уверен, что с PostgreSQL должно работать аналогично.

    Михаиллл
    • Jan. 6, 2019, 7:09 a.m.

    Но в PSQL нет типа BLOB. Как думаете, подойдет ли bytea (двоичные данные («массив байт»))?

      Evgenii Legotckoi
      • Jan. 6, 2019, 7:11 a.m.
      • The answer was marked as a solution.

      Это он и есть

        Ruslan Polupan
        • Jan. 6, 2019, 12:19 p.m.

        Если изображений не много то проще хранить в БД. если больше 1000 то лучще хранить ссылки на изображния. Основной критерий бэкап базы данных.

          Михаиллл
          • Jan. 7, 2019, 6:23 a.m.

          А если их много, но они не очень большие?
          На какой объем памяти лучше ориентироваться?

            Evgenii Legotckoi
            • Jan. 7, 2019, 8:50 a.m.

            Да это всё равно лишняя нагрузка на приложение, создавать изображение из QByteArray, который был в базе данных, довольно накладная операция, чем просто открыть изображение, по моему мнению.

            Чем вызвано ваше желание именно в базу данных поместить изображения?

              Михаиллл
              • Jan. 8, 2019, 2:46 a.m.

              думал что так будет удобней хранить инфорацию.
              также прикинул что объем памяти будет занят тот же, но просто в другом месте.
              и подумал что перевод изибражения в QByteArray и обратно займет только несколько милисекунд, что не принципиально.

                Evgenii Legotckoi
                • Jan. 8, 2019, 3:14 a.m.

                Ну, теоретически, наверное да, практически, вы можете утратить некоторую информацию. В статье, которую я вам показывал, вы забираете QByteArray из QPixmap, а значит не имеете служеюной информации, там наверняка не вся информация будет содержаться, которая по факту добавляется в изображение. (Я имею ввиду поворот изображения или ещё что-нибудь в этом роде).

                Как бы да, хранилище получается другое. Но тем не менее, по-моему, лишняя нагрузка будет. Я смотрю на это с точки зрения создания сайта, вы видимо с точки зрения другого приложения.

                Не знаю, попробуйте реализовать с базой данных, а когда будет много изображений, то проверьте на лишь с хранением путей.

                Но я в той статье всё равно хранил название файла, то есть поле под имя/путь файла всё равно было, а хранение изображения было дополнительным полем.

                  Михаиллл
                  • Jan. 8, 2019, 3:50 a.m.

                  Спасибо

                    Comments

                    Only authorized users can post comments.
                    Please, Log in or Sign up
                    AD

                    C ++ - Test 004. Pointers, Arrays and Loops

                    • Result:50points,
                    • Rating points-4
                    m

                    C ++ - Test 004. Pointers, Arrays and Loops

                    • Result:80points,
                    • Rating points4
                    m

                    C ++ - Test 004. Pointers, Arrays and Loops

                    • Result:20points,
                    • Rating points-10
                    Last comments
                    i
                    innorwallNov. 15, 2024, 5:44 a.m.
                    Qt/C++ - Lesson 039. How to paint stroke in QSqlTableModel by value in the column? Many OPKs would advise users to start using the test strips around day 9 of your cycle, considering day 1 to be the first day of full menstrual flow buy priligy australia
                    i
                    innorwallNov. 15, 2024, 2:27 a.m.
                    Release of C++/Qt and QML application deployment utility CQtDeployer v1.4.0 (Binary Box) optionally substituted alkoxy, optionally substituted alkenyloxy, optionally substituted alkynyloxy, optionally substituted aryloxy, OCH, OC H, OC H, OC H, OC H, OC H, OC H, O C CH, OCH CH OH, O…
                    i
                    innorwallNov. 14, 2024, 9:26 p.m.
                    Qt/C++ - Lesson 031. QCustomPlot – The build of charts with time buy generic priligy We can just chat, and we will not lose too much time anyway
                    i
                    innorwallNov. 14, 2024, 7:03 p.m.
                    Qt/C++ - Lesson 060. Configuring the appearance of the application in runtime I didnt have an issue work colors priligy dapoxetine 60mg revia cost uk August 3, 2022 Reply
                    i
                    innorwallNov. 14, 2024, 12:07 p.m.
                    Circuit switching and packet data transmission networks Angioedema 1 priligy dapoxetine
                    Now discuss on the forum
                    t
                    tonypeachey1Nov. 15, 2024, 6:04 a.m.
                    google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
                    i
                    innorwallNov. 15, 2024, 5:50 a.m.
                    добавить qlineseries в функции priligy for sale Gently flush using an ear syringe
                    i
                    innorwallNov. 11, 2024, 10:55 a.m.
                    Всё ещё разбираюсь с кешем. 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
                    9AnonimOct. 25, 2024, 9:10 a.m.
                    Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

                    Follow us in social networks