Михаиллл
Михаиллл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
                    ИМ
                    Игорь МаксимовNov. 22, 2024, 10:51 p.m.
                    Django - Tutorial 017. Customize the login page to Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
                    Evgenii Legotckoi
                    Evgenii LegotckoiNov. 1, 2024, 12:37 a.m.
                    Django - Lesson 064. How to write a Python Markdown extension Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
                    A
                    ALO1ZEOct. 19, 2024, 6:19 p.m.
                    Fb3 file reader on Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                    ИМ
                    Игорь МаксимовOct. 5, 2024, 5:51 p.m.
                    Django - Lesson 064. How to write a Python Markdown extension Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                    d
                    dblas5July 5, 2024, 9:02 p.m.
                    QML - Lesson 016. SQLite database and the working with it in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                    Now discuss on the forum
                    Evgenii Legotckoi
                    Evgenii LegotckoiJune 25, 2024, 1:11 a.m.
                    добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
                    t
                    tonypeachey1Nov. 15, 2024, 5:04 p.m.
                    google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
                    NSProject
                    NSProjectJune 4, 2022, 1:49 p.m.
                    Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…
                    9
                    9AnonimOct. 25, 2024, 7:10 p.m.
                    Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

                    Follow us in social networks