sql >> Databáze >  >> RDS >> Sqlserver

3 způsoby, jak vrátit řádky, které obsahují alfanumerické znaky na serveru SQL

Zde jsou tři příklady vracení řádků, které obsahují alfanumerické znaky v SQL Server.

Alfanumerické znaky jsou abecední a číselné znaky.

Ukázková data

Předpokládejme, že máme následující tabulku:

CREATE TABLE t1 (
    c1 varchar(255) NULL
    );

INSERT INTO t1 VALUES
    ('Music'),
    ('Live Music'),
    ('Café'),
    ('Café Del Mar'),
    ('100 Cafés'),
    ('[email protected]'),
    ('1 + 1'),
    ('()'),
    ('[email protected]#&()–[{}]:;'',?/*'),
    ('`~$^+=<>“'),
    ('$1.50'),
    ('Player 456'),
    ('007'),
    (null),
    (''),
    ('é'),
    ('É'),
    ('é 123'),
    ('ø'),
    ('ø 123');
SELECT c1 FROM t1;

Výsledek:

+----------------------+
| c1                   |
+----------------------+
| Music                |
| Live Music           |
| Café                 |
| Café Del Mar         |
| 100 Cafés            |
| [email protected]    |
| 1 + 1                |
| ()                   |
| [email protected]#&()–[{}]:;',?/*   |
| `~$^+=<>“            |
| $1.50                |
| Player 456           |
| 007                  |
| NULL                 |
|                      |
| é                    |
| É                    |
| é 123                |
| ø                    |
| ø 123                |
+----------------------+

Příklad 1:Řádek obsahuje alfanumerická data

Následující kód vrací řádky, které obsahují alfanumerické znaky (a mohou také obsahovat nealfanumerické znaky):

SELECT c1 FROM t1
WHERE c1 LIKE '%[a-zA-Z0-9]%';

Výsledek:

+-------------------+
| c1                |
|-------------------|
| Music             |
| Live Music        |
| Café              |
| Café Del Mar      |
| 100 Cafés         |
| [email protected] |
| 1 + 1             |
| $1.50             |
| Player 456        |
| 007               |
| é                 |
| É                 |
| é 123             |
| ø                 |
| ø 123             |
+-------------------+

Příklad 2:Řádek obsahuje POUZE alfanumerická data

Následující kód vrátí řádky, které obsahují pouze alfanumerické znaky:

SELECT c1 FROM t1
WHERE c1 NOT LIKE '%[^a-zA-Z0-9]%'
AND c1 LIKE '%[a-zA-Z0-9]%';

Výsledek:

+-------+
| c1    |
|-------|
| Music |
| Café  |
| 007   |
| é     |
| É     |
| ø     |
+-------+

Mezery jsou považovány za nealfanumerické. Mezery můžeme zahrnout úpravou kódu na následující:

SELECT c1 FROM t1
WHERE c1 NOT LIKE '%[^a-zA-Z0-9 ]%'
AND c1 LIKE '%[a-zA-Z0-9 ]%';

Výsledek:

+--------------+
| c1           |
|--------------|
| Music        |
| Live Music   |
| Café         |
| Café Del Mar |
| 100 Cafés    |
| Player 456   |
| 007          |
| é            |
| É            |
| é 123        |
| ø            |
| ø 123        |
+--------------+

Příklad 3:Alternativní metoda

Alternativně můžeme použít PATINDEX() k dosažení stejného výsledku.

Následující kód vrátí řádky, které obsahují pouze alfanumerické znaky:

SELECT c1 FROM t1
WHERE PATINDEX('%[^0-9a-zA-Z]%', c1) = 0 
AND PATINDEX('%[a-zA-Z0-9]%', c1) > 0;

Výsledek:

+-------+
| c1    |
|-------|
| Music |
| Café  |
| 007   |
| é     |
| É     |
| ø     |
+-------+

A s mezerami:

SELECT c1 FROM t1
WHERE PATINDEX('%[^0-9a-zA-Z ]%', c1) = 0 
AND PATINDEX('%[a-zA-Z0-9 ]%', c1) > 0;

Výsledek:

+--------------+
| c1           |
|--------------|
| Music        |
| Live Music   |
| Café         |
| Café Del Mar |
| 100 Cafés    |
| Player 456   |
| 007          |
| é            |
| É            |
| é 123        |
| ø            |
| ø 123        |
+--------------+

  1. PostgreSQL Full Text Search a Trigram Confusion

  2. Použití ADO asynchronně v aplikaci Microsoft Access k urychlení formulářů

  3. Třídicí strom se zhmotněnou cestou?

  4. Použití OASIS-SVN a git pro řízení zdrojového kódu Access