172 похожих чатов

Коллеги, кто может подсказать момент один, суть такова пишем процедурку,

переменную в квере приводим к интегеру явно variable::integer in (… , 2147483648, …), значение в массиве переполняет постгерсовый тип интегер, вопрос, как на более низком уровне прокатывает такая штука в кверях (то есть это в квере массив, возможно расширивший хранимый тип)? могу ошибаться, но когда работал в cracker’e помнится что кто-то упоминал(возможно даже Володя Ситников, но там речь про оракл, а вопрос у меня по постгре) что in работает через сравнение строк и все переводится в строки, так ли это?

10 ответов

11 просмотров

Int8

Denis-Karasev Автор вопроса
doc
Int8

ок, а можно чуть более развернуто, по поводу in clause

Я вообще ничего не понял. :( > переменную в квере приводим к интегеру явно variable::integer in (… , 2147483648, …), значение в массиве переполняет постгерсовый тип интегер WITH t(v) AS ( VALUES (5), (21) ) SELECT v, v::integer IN (12, 2147483648, 43, 5) FROM t; И ничего не переполняется... > но там речь про оракл Который не имеет к PostgreSQL никакого отношения? ;) > , а вопрос у меня по постгре) СУБД называется постгреc. > что in работает через сравнение строк и все переводится в строки, так ли это? Конечно, нет.

Denis-Karasev Автор вопроса
Yaroslav Schekin
Я вообще ничего не понял. :( > переменную в квере...

а если массив вынести в declare? все сразу переполнится и перестанет компилиться)))

Denis-Karasev Автор вопроса
Yaroslav Schekin
Я вообще ничего не понял. :( > переменную в квере...

вы ответили что не как строки, а как именно можете рассказать поподробней?

Denis Karasev
вы ответили что не как строки, а как именно можете...

IN с константами преобразуется в "= ANY (<массив какого-то типа>)" (вывод типов осуществляется по стандартным принципам, т.е. получается "самый широкий" тип среди констант в этом случае, грубо говоря). Далее выполняется оператор для этих типов данных, и всё.

Denis-Karasev Автор вопроса
Yaroslav Schekin
IN с константами преобразуется в "= ANY (<массив к...

то есть, когда мы приводим какое-то искомое значение к интегеру и пытаемся искать в подобном массиве с переполнением значения (как в примере), он просто расширяет тип и просто преобразует искомое(если это нужно, как в яп), ок, спасибо))

Denis Karasev
то есть, когда мы приводим какое-то искомое значен...

"Как в примере" (вот этом https://t.me/pgsql/264293 ) код вообще не работает, т.к. bigint[] в int[] не сохранишь (строгая типизация). А так, в общем, да... Вы лучше попробуйте на примерах.

Похожие вопросы

Обсуждают сегодня

Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
И никого не интересует какие пакеты кто использует. ((% Заходишь на сайт симфони и видишь поддержку Украины - по законам РФ это ж экстремизм. Только никто не отказывается от с...
Am Ambrion
11
лучше скажите, причём тут паскаль?
Alexey Kulakov
36
Чтобы перехватить все нажимания буков на форме, надо хук ставить? Пробовал на форме ОнКейДаун, оно ловит клаву если фокус не на компоненте с вводом текста
Serjone
15
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
7
Народ! Впервые клиенту пришло письмо от РКН, у вас, дескать, есть яндекс метрика, а нигде не написано, что вы ее юзаете. Никто не сталкивался?
Sasha Beep
14
Всем привет! вывожу на общей стр дочерние ресурсыв каждом ресурсе галерея, и первая фотка должна выводиться на общей [!DocLister? &prepare=photo !]
Alekso
12
Я правильно понимаю что нет способов получить список ожидающих заявок на вступление в группу с помощью бота из mtproto?
Шамиль Прилов
7
А можно вопрос? Мне сегодня сказали что у меня функция (которая просто заполняет массив значениями) не правильная void Full(double * arr, int n) { for (int i = 0; i < n; i...
† C E †
7
Добрый вечер. Хочу чтобы у меня в классе поле было функцией, которая возвращает строку. Делаю так: interface ... TGetOutPath = function : String of object; ... protec...
Kirill Filippenok
12
Карта сайта