Função POSITION
Retorna a localização da substring especificada dentro de uma string.
Consulte Função CHARINDEX e Função STRPOS para ver funções semelhantes.
Sintaxe
POSITION(substring IN string )
Argumentos
- substring
-
A substring a procurar dentro da string.
- string
-
A string ou coluna a ser procurada.
Tipo de retorno
A função POSITION retorna um INTEGER
correspondente à posição da substring (baseada em 1, não baseada em zero). A posição é baseada no número de caracteres, e não bytes, de forma que caracteres multibyte são contados como caracteres simples. POSITION retornará 0
se a substring não for localizada dentro da string.
Exemplos
Para retornar a posição da string fish
na palavra dog
, use o exemplo a seguir.
SELECT POSITION('fish' IN 'dog');
+-----------+ | position | +-----------+ | 0 | +-----------+
Para retornar a posição da string fish
na palavra dogfish
, use o exemplo a seguir.
SELECT POSITION('fish' IN 'dogfish');
+-----------+ | position | +-----------+ | 4 | +-----------+
O exemplo a seguir usa a tabela SALES do exemplo de banco de dados TICKIT. Para ter mais informações, consulte Banco de dados de exemplo.
Para retornar o número de transações de vendas distinta com uma comissão acima de 999,00 da tabela SALES, use o exemplo a seguir. Esse comando conta comissões maiores que 999,00 verificando se o decimal está acima de quatro casas a partir do início do valor da comissão.
SELECT DISTINCT POSITION('.' IN commission), COUNT (POSITION('.' IN commission)) FROM sales WHERE POSITION('.' IN commission) > 4 GROUP BY POSITION('.' IN commission) ORDER BY 1,2;
+-----------+-------+ | position | count | +-----------+-------+ | 5 | 629 | +-----------+-------+