PostgreSQL
 sql >> Database >  >> RDS >> PostgreSQL

Rileva se un valore contiene almeno una cifra numerica in PostgreSQL

L'esempio seguente restituisce tutte le righe che contengono almeno una cifra numerica in PostgreSQL.

Esempio

Supponiamo di avere una tabella chiamata Products con i seguenti dati nel suo ProductName colonna:

SELECT ProductName 
FROM Products;

Risultato:

           productname           
---------------------------------
 Left handed screwdriver
 Right handed screwdriver
 Long Weight (blue)
 Long Weight (green)
 Straw Dog Box
 Bottomless Coffee Mugs (4 Pack)
 Smash 2000 Sledge Hammer
 Chainsaw (3 spare fingers)

Questa colonna contiene dati carattere, ma alcune righe contengono numeri all'interno di tali dati carattere (anche se non sono archiviati come tipo numerico).

Possiamo utilizzare la seguente query per restituire solo quelle righe che contengono numeri rappresentati da cifre numeriche:

SELECT ProductName 
FROM Products
WHERE ProductName ~ '[0-9]+';

Risultato:

           productname           
---------------------------------
 Bottomless Coffee Mugs (4 Pack)
 Smash 2000 Sledge Hammer
 Chainsaw (3 spare fingers)

Come previsto, vengono restituite solo le righe che contengono numeri.

In PostgreSQL, ~ è un operatore con distinzione tra maiuscole e minuscole per la corrispondenza dell'espressione regolare data. Per le corrispondenze senza distinzione tra maiuscole e minuscole, usa ~* .

Puoi usare !~ per restituire tutte le righe che non corrispondono all'espressione regolare (e !~* per le corrispondenze senza distinzione tra maiuscole e minuscole).