• Может ли ClickHouse заменить Mysql?

    Melkij
    @Melkij
    PostgreSQL DBA
    Колоночная и реляционная базы. У них банально разные области применения
    Ответ написан
    Комментировать
  • Как записать образ карты пямяти с двумя разделами?

    Melkij
    @Melkij
    PostgreSQL DBA
    Если вам нужен образ всей флешки, то зачем вам копировать отдельно разделы? Копируйте всю флешку целиком.
    sudo dd if=/dev/mmcblk0 of=/media/root/Rasp_1.img bs=1M


    А если надо разделы в отдельности - то и копируйте их каждый в отдельности.
    Ответ написан
    Комментировать
  • Какой IT специалист занимается проработкой разделов Terms and Conditions и Privacy policy?

    Melkij
    @Melkij
    PostgreSQL DBA
    Юрист.
    Ответ написан
    Комментировать
  • Возможно ли делать ALTER на PG10?

    Melkij
    @Melkij
    PostgreSQL DBA
    Ибо эат команда, разумеется, уже не работает.

    Почему "разумеется"?
    pglogical никуда не делся. Как был сторонним модулем, так и остался. Релиз с поддержкой PG11 тоже уже был.

    А логическая репликация которая штатная в pg10 - DDL не обрабатывает. Это опять же обязанность сопровождающего систему админа корректно вносить DDL.
    Ответ написан
  • Как задать условие выборки более старых записей по времени?

    Melkij
    @Melkij
    PostgreSQL DBA
    и проверяет работоспособность IP выбирая только 25 штук

    Ну и где эта часть запроса?
    Поправьте свой order by на сортировку по дате проверки. И будете получать записи проверенные наибольшее время назад.
    Ответ написан
    Комментировать
  • Защита от mysql инъекций без средств pdo?

    Melkij
    @Melkij
    PostgreSQL DBA
    mysqli_query (сам удивлён как он до сих пор живой)

    А в чём проблема? mysqli жив и поддерживается, у них даже частично кодовая база с pdo_mysql пересекается - если с mysqlnd собирать.

    mysqli предоставляет интерфейс prepared statements. Ну экспорт escape тоже есть.
    Ответ написан
    Комментировать
  • Что значит "--" флаг во многих git операциях?

    Melkij
    @Melkij
    PostgreSQL DBA
    Многие консольные команды разбирают переданные им параметры используя вызов getopt

    getopt отдельно выделяет аргумент "--" как маркер окончания списка параметров:
    The special argument "--" forces an end of option-scanning regardless of the scanning mode.


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

    В частности, git reset использует это поведение для однозначного отделения имён файлов: всё после -- будет восприниматься как имена файлов вместо чего-то вот такого:
    $ git reset file
    fatal: ambiguous argument 'file': unknown revision or path not in the working tree.
    Use '--' to separate paths from revisions, like this:
    'git [...] -- [...]'
    Ответ написан
    Комментировать
  • Как востановить базу из файлов?

    Melkij
    @Melkij
    PostgreSQL DBA
    Если в директории C:\Program Files\PostgreSQL\9.1\data (далее буду называть $PGDATA) лежат директории base, global, pg_xlog и всякое прочее преимущественно с префиксом pg_* - то надежда есть. Если в pg_xlog лежат куча странных файлов, а pg_tblspc пусто либо ссылки из него живые. Сделайте бекап $PGDATA и содержимого pg_tblspc (если там были ссылки).

    Затем ставите сервер версии 9.1.24. Настраиваете data_directory смотреть в ваш $PGDATA. Пробуете запустить СУБД и смотрите в лог базы что происходит.

    pg_upgrade требует заведомо работающих и корректно остановленных кластеров и старой версии и новой. Откажется работать даже если база была выключена аварийно.
    Ответ написан
    Комментировать
  • Как проверять поля на то, чтобы только одно из них было не пусто?

    Melkij
    @Melkij
    PostgreSQL DBA
    Вам нужен check constraint.

    XOR в postgresql вроде нет, так что показывать на пальцах:
    alter table tablename add constraint tablename_p1_xor_p2 check((p1 is null and p2 is not null) or (p2 is null and p1 is not null));
    Ответ написан
    Комментировать
  • RAID-1, почему не видно все разделы?

    Melkij
    @Melkij
    PostgreSQL DBA
    В /proc/mdstat только дисковые массивы, активные сейчас. И, опять же, только тома входящие в этот массив. Если вы делали странное (а вы делали странное) - то ядро вполне резонно решило, что желает пообщаться с оператором.

    Вам необходимо взять тот диск, версию которого вы хотите оставить (поскольку вы с них загружались независимо друг от друга - у вас теперь два разных массива. md2, как видно, не модифицировался и пережил издевательства) и добавить необходимые разделы в массив. -r (remove) вполне ожидаемо отвечает что не может удалить том, которого в массиве нет.
    Ответ написан
  • О чем говорит эта ошибка?

    Melkij
    @Melkij
    PostgreSQL DBA
    Вас прямым текстом спрашивают и куда смотреть и что делать:
    Is the server running on host "180.20.10.1" and accepting
    TCP/IP connections on port 45433?


    На указанном адресе СУБД запущена? На этом порту?
    Ответ написан
    2 комментария
  • Можно ли организовать доступ к сайту про IPv6?

    Melkij
    @Melkij
    PostgreSQL DBA
    Да, настроить доступ по ipv6 можно.
    Если вы дадите только ipv6 записи и откажитесь от ipv4 - то сайт будет открываться примерно у 2% пользователей России, согласно статистики google.
    Ответ написан
  • Как правильно прописать конфиг для Hibernate?

    Melkij
    @Melkij
    PostgreSQL DBA
    Java - это такой специальный язык для генерации километровых backtrace...

    Почему получив null value in column violates not-null constraint вы решили, что у вас проблема с подключением к СУБД? Вы пытаетесь вставить NULL в поле отмеченное как NOT NULL. Судя по тексту запроса - у вас не указано default значение для этого поля.
    Ответ написан
    4 комментария
  • Есть ли официальные правила выделения портов Postgresql в зависимости от версии?

    Melkij
    @Melkij
    PostgreSQL DBA
    Нет, гарантии нет. Менять привычный 5432 порт у сообщества причин нет. Теоретически поменять дефолтный порт можем, это не так сложно технически - но зачем? Мы не гарантируем совместимость с последующими версиями и вполне можем решить что-нибудь сломать нужное, если сообщество согласится что оно того стоит. Гарантий не дадим, но вполне можно рассчитывать что будет 5432 ещё очень долго использоваться по умолчанию, нет причин его менять и есть веские причины его не менять.

    Ну и стоит упомянуть, что дефолтный порт может быть указан в конфигах, параметром запуска, и в том числе на этапе компиляции базы:
    --with-pgport=PORTNUM set default port number [5432]


    Пока он как-то сам выбирает порт

    PostgreSQL не занимается таким. Просто откажется стартовать если не удастся открыть сокет. Номер порта не менялся очень давно, если менялся вообще хоть когда-нибудь от самого основания ещё post-ingres в 198х годах.

    Вот сторонние скрипты - те могут иметь какую-нибудь такую логику. Например, пакеты debian/ubuntu при вызове pg_createcluster попробует прописать в конфиге ближайший свободный порт начиная с 5432. Никакой зависимости от версии СУБД нет. Нужен новый кластер? Ок, возьмём ближайший свободный порт и настроим на использование его.
    Ответ написан
    3 комментария
  • Какие могут быть обоснования для ограничения штрафов по договору?

    Melkij
    @Melkij
    PostgreSQL DBA
    Напрягает - значит просите изменить. Например, ограничить сверху суммой договора. Зачем вам обоснование? Вас не устраивает такое положение в договоре, вы вольны не подписывать договор. Договорные отношения потому и договорные.
    Ответ написан
    Комментировать
  • Как настроить строку соединения к базе данных?

    Melkij
    @Melkij
    PostgreSQL DBA
    Схемы - дополнительный уровень упорядочивания сущностей.
    Варианты на выбор: указывать схему в именах объектов в запросах (обычно) либо менять search_path на необходимый.

    Именно поэтому имя схемы - это атрибут в аннотации самой таблицы, а не строки подключения.
    https://www.doctrine-project.org/projects/doctrine...
    Ответ написан
  • Смена движка InnoDB → MyISAM на таблице с триггерами?

    Melkij
    @Melkij
    PostgreSQL DBA
    Делаете бекап, конвертируете, проверяете.
    Так-то триггеры живут уровнем выше storage engine и задеть не должны.

    PS: и стоит ещё раз внимательно подумать, точно ли хорошая идея менять транзакционный innodb на какую-то кучу бинарного мусора. Если вы понимаете, что транзакционность - это не только про слова begin/commit.
    Ответ написан
    Комментировать
  • Почему пользователю БД не назначаются права?

    Melkij
    @Melkij
    PostgreSQL DBA
    postgres=# CREATE DATABASE joba_finder;
    CREATE DATABASE
    postgres=# CREATE USER jf_user WITH PASSWORD 'qwerty';
    CREATE ROLE
    postgres=# \l joba_finder 
                                   Список баз данных
         Имя     | Владелец | Кодировка | LC_COLLATE  |  LC_CTYPE   | Права доступа 
    -------------+----------+-----------+-------------+-------------+---------------
     joba_finder | postgres | UTF8      | ru_RU.UTF-8 | ru_RU.UTF-8 | 
    (1 строка)
    
    postgres=# GRANT ALL PRIVILEGES ON DATABASE joba_finder to jf_user;
    GRANT
    postgres=# \l joba_finder 
                                       Список баз данных
         Имя     | Владелец | Кодировка | LC_COLLATE  |  LC_CTYPE   |     Права доступа     
    -------------+----------+-----------+-------------+-------------+-----------------------
     joba_finder | postgres | UTF8      | ru_RU.UTF-8 | ru_RU.UTF-8 | =Tc/postgres         +
                 |          |           |             |             | postgres=CTc/postgres+
                 |          |           |             |             | jf_user=CTc/postgres
    (1 строка)
    
    postgres=# select version();
                                                    version                                                 
    --------------------------------------------------------------------------------------------------------
     PostgreSQL 11.2 (Debian 11.2-2) on x86_64-pc-linux-gnu, compiled by gcc (Debian 8.3.0-2) 8.3.0, 64-bit
    (1 строка)

    Just works. Настройками это не регулируется, так что проверяйте что вы делаете не так. Может быть не коммитите транзакцию с grant? Не знаю.

    Не заметил:

    joba_finder-# \l

    Внимание на -# так где должен быть =# - метка указывает, что вы начали писать запрос, но не завершили его. psql команды вроде \l при этом всё ещё обрабатываются.
    postgres=# select
    postgres-# \l joba_finder 
                                       Список баз данных
         Имя     | Владелец | Кодировка | LC_COLLATE  |  LC_CTYPE   |     Права доступа     
    -------------+----------+-----------+-------------+-------------+-----------------------
     joba_finder | postgres | UTF8      | ru_RU.UTF-8 | ru_RU.UTF-8 | =Tc/postgres         +
                 |          |           |             |             | postgres=CTc/postgres+
                 |          |           |             |             | jf_user=CTc/postgres
    (1 строка)
    
    postgres-# 1;
     ?column? 
    ----------
            1
    (1 строка)

    Как пример psql команды в середине написания select 1;
    Ответ написан
    3 комментария
  • Какие ключевые отличия PCRE2 от PCRE?

    Melkij
    @Melkij
    PostgreSQL DBA
    https://wiki.php.net/rfc/pcre2-migration
    The userland code is unaffected


    Ключевые отличия - изменения C API. Потому смена major версии библиотеки.
    Ответ написан
    Комментировать
  • Не могу вписать условие в базу данных?

    Melkij
    @Melkij
    PostgreSQL DBA
    alter column "id" что? По синтаксису дальше идёт описание действия, а не непонятно откуда взявшееся слово INTEGER

    Если это самодеятельность вашего gui - то это приложение не умеет работать с postgresql, только и всего. Возьмите что-нибудь адекватное. psql например.

    Ну и default должен быть не в кавычках, а именно вызовом функции, set default nextval(...
    Ответ написан
    Комментировать