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).