Запросы к базе данных
опасность
Помните, что вмешательство в базу данных может привести к непредсказуемым последствиям. По возможности избегайте прямого изменения базы данных и всегда делайте резервные копии.
совет
Выполните команду docker exec -it immich_postgres psql --dbname=<DB_DATABASE_NAME> --username=<DB_USERNAME>
для подключения к базе данных напрямую через контейнер.
(Замените <DB_DATABASE_NAME>
и <DB_USERNAME>
на значения из вашего .env
файла).
Активы
Имя
заметка
Колонка "originalFileName"
содержит имя файла на момент загрузки, включая расширение.
Поиск по оригинальному имени файла
SELECT * FROM "asset" WHERE "originalFileName" = 'PXL_20230903_232542848.jpg';
SELECT * FROM "asset" WHERE "originalFileName" LIKE 'PXL_%'; -- все файлы, начинающиеся с PXL_
SELECT * FROM "asset" WHERE "originalFileName" LIKE '%_2023_%'; -- все файлы с _2023_ в середине
Поиск по пути
SELECT * FROM "asset" WHERE "originalPath" = 'upload/library/admin/2023/2023-09-03/PXL_2023.jpg';
SELECT * FROM "asset" WHERE "originalPath" LIKE 'upload/library/admin/2023/%';
ID
Поиск по ID
SELECT * FROM "asset" WHERE "id" = '9f94e60f-65b6-47b7-ae44-a4df7b57f0e9';
Поиск по частичному ID
SELECT * FROM "asset" WHERE "id"::text LIKE '%ab431d3a%';
Контрольная сумма
заметка
Вы можете вычислить контрольну ю сумму для конкретного файла, используя команду sha1sum <filename>
.
Поиск по контрольной сумме (SHA-1)
SELECT encode("checksum", 'hex') FROM "asset";
SELECT * FROM "asset" WHERE "checksum" = decode('69de19c87658c4c15d9cacb9967b8e033bf74dd1', 'hex');
SELECT * FROM "asset" WHERE "checksum" = '\x69de19c87658c4c15d9cacb9967b8e033bf74dd1'; -- альтернативный формат
Поиск дублирующихся активов с идентичной контрольной суммой (SHA-1) ( исключая удаленные файлы)
SELECT T1."checksum", array_agg(T2."id") ids FROM "asset" T1
INNER JOIN "asset" T2 ON T1."checksum" = T2."checksum" AND T1."id" != T2."id" AND T2."deletedAt" IS NULL
WHERE T1."deletedAt" IS NULL GROUP BY T1."checksum";
Метаданные
Живые фото
SELECT * FROM "asset" WHERE "livePhotoVideoId" IS NOT NULL;
По описанию
SELECT "asset".*, "asset_exif"."description" FROM "asset_exif"
JOIN "asset" ON "asset"."id" = "asset_exif"."assetId"
WHERE TRIM("asset_exif"."description") <> ''; -- все файлы с описанием
SELECT "asset".*, "asset_exif"."description" FROM "asset_exif"
JOIN "asset" ON "asset"."id" = "asset_exif"."assetId"
WHERE "asset_exif"."description" ILIKE '%строка для поиска%'; -- поиск по строке
Файлы без метаданных
SELECT "asset".* FROM "asset_exif"
LEFT JOIN "asset" ON "asset"."id" = "asset_exif"."assetId"
WHERE "asset_exif"."assetId" IS NULL;
Размер < 100,000 байт, от меньшего к большему
SELECT * FROM "asset"
JOIN "asset_exif" ON "asset"."id" = "asset_exif"."assetId"
WHERE "asset_exif"."fileSizeInByte" < 100000
ORDER BY "asset_exif"."fileSizeInByte" ASC;
Тип
По типу
SELECT * FROM "asset" WHERE "asset"."type" = 'VIDEO';
SELECT * FROM "asset" WHERE "asset"."type" = 'IMAGE';
Количество по типу
SELECT "asset"."type", COUNT(*) FROM "asset" GROUP BY "asset"."type";
Количество по типу (по пользователям)
SELECT "user"."email", "asset"."type", COUNT(*) FROM "asset"
JOIN "user" ON "asset"."ownerId" = "user"."id"
GROUP BY "asset"."type", "user"."email" ORDER BY "user"."email";
Теги
Количество по тегам
SELECT "t"."value" AS "tag_name", COUNT(*) AS "number_assets" FROM "tag" "t"
JOIN "tag_asset" "ta" ON "t"."id" = "ta"."tagsId" JOIN "asset" "a" ON "ta"."assetsId" = "a"."id"
WHERE "a"."visibility" != 'hidden'
GROUP BY "t"."value" ORDER BY "number_assets" DESC;
Количество по тегам (по пользователям)
SELECT "t"."value" AS "tag_name", "u"."email" as "user_email", COUNT(*) AS "number_assets" FROM "tag" "t"
JOIN "tag_asset" "ta" ON "t"."id" = "ta"."tagsId" JOIN "asset" "a" ON "ta"."assetsId" = "a"."id" JOIN "user" "u" ON "a"."ownerId" = "u"."id"
WHERE "a"."visibility" != 'hidden'
GROUP BY "t"."value", "u"."email" ORDER BY "number_assets" DESC;
Пользователи
Список всех пользователей
SELECT * FROM "user";
Получить информацию о владельце по ID актива
SELECT "user".* FROM "user" JOIN "asset" ON "user"."id" = "asset"."ownerId" WHERE "asset"."id" = 'fa310b01-2f26-4b7a-9042-d578226e021f';
Персоны
Удалить персону и отвязать её от изображений, с которыми она связана
DELETE FROM "person" WHERE "name" = 'PersonNameHere';
Система
Конфигурация
Пользовательские настройки
SELECT "key", "value" FROM "system_metadata" WHERE "key" = 'system-config';
(Используется только, если не применяется файл конфигурации)
Свойства файлов
Без миниатюр
SELECT * FROM "asset" WHERE "asset"."previewPath" IS NULL OR "asset"."thumbnailPath" IS NULL;
Неудачные перемещения файлов
SELECT * FROM "move_history";
Внутренние операции PostgreSQL
Изменение DB_PASSWORD
ALTER USER <DB_USERNAME> WITH ENCRYPTED PASSWORD 'newpasswordhere';