Estou tentando pegar os últimos quatro caracteres apenas de um campo varchar. Todas as linhas têm comprimentos diferentes. Que função devo usar para fazer isso?
Respostas:
O certo deve servir:
select RIGHT('abcdeffff',4)
SUBSTR(column, LENGTH(column) - 3, 4)
LENGTH
retorna o comprimento da string e SUBSTR
4 caracteres de "comprimento da posição - 4"
SUBSTR(column, LENGTH(column) - 3, 4)
. Se o comprimento for 4, precisamos começar na posição 1 e pegar 4 caracteres.
RIGHT ( character_expression , integer_expression )
SELECT RIGHT(column, 4) FROM ...
Também uma lista de outras funções de string .
Use a RIGHT()
função: http://msdn.microsoft.com/en-us/library/ms177532(v=sql.105).aspx
SELECT RIGHT( '1234567890', 4 ); -- returns '7890'
Para Oracle SQL, SUBSTR(column_name, -# of characters requested)
extrairá os últimos três caracteres para uma determinada consulta. por exemplo
SELECT SUBSTR(description,-3) FROM student.course;
solução testada no hackerrank ....
select distinct(city) from station
where substr(lower(city), length(city), 1) in ('a', 'e', 'i', 'o', 'u') and substr(lower(city), 1, 1) in ('a', 'e', 'i', 'o', 'u');