Главная > MySQL > Firebird SELECT MAX CAST AS INT

Firebird SELECT MAX CAST AS INT

Задача: нужно выбрать максимальное число из поля, формат которого текстовый.
При следующем запросе будет сделана выборка по алфавиту. т.е. будет выбрано, например, 999, когда присутствует значение 1000

SELECT MAX(HISTNUM) FROM CLIENTS

Обычно это решается так:

SELECT MAX(CAST(HISTNUM AS INT)) FROM CLIENTS

но в Firebird следующая ошибка:

conversion error from string ""
GDSCODE = 335544334
SQLCODE = -413

Решение: отсортировать вначале по длине строки, затем по алфавиту, выбрав одну строку. Варианты:

SELECT HISTNUM FROM CLIENTS ORDER BY CHAR_LENGTH(HISTNUM) DESC, HISTNUM DESC ROWS 1
SELECT HISTNUM FROM CLIENTS ORDER BY CHAR_LENGTH(HISTNUM) DESC, HISTNUM DESC ROWS 1 TO 1
SELECT FIRST 1 SKIP 0 HISTNUM FROM CLIENTS ORDER BY CHAR_LENGTH(HISTNUM) DESC, HISTNUM DESC

В конкретном случае нужно было еще сделать проверку на максимальную длину этого числа. Варианты:

SELECT HISTNUM FROM CLIENTS WHERE CHAR_LENGTH(HISTNUM)<7 ORDER BY CHAR_LENGTH(HISTNUM) DESC, HISTNUM DESC ROWS 1
SELECT FIRST 1 SKIP 0 HISTNUM FROM CLIENTS WHERE CHAR_LENGTH(HISTNUM)<7 ORDER BY CHAR_LENGTH(HISTNUM) DESC, HISTNUM DESC
Categories: MySQL Tags: ,
  1. Пока что нет комментариев.
Похожие публикации