sql >> Database >  >> RDS >> Sqlserver

3 manieren om rijen te retourneren die alfanumerieke tekens bevatten in SQL Server

Hier zijn drie voorbeelden van het retourneren van rijen die alfanumerieke tekens bevatten in SQL Server.

Alfanumerieke tekens zijn alfabetische en numerieke tekens.

Voorbeeldgegevens

Stel dat we de volgende tabel hebben:

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;

Resultaat:

+----------------------+
| 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                |
+----------------------+

Voorbeeld 1:Rij bevat alfanumerieke gegevens

De volgende code retourneert rijen die alfanumerieke tekens bevatten (en kunnen ook niet-alfanumerieke tekens bevatten):

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

Resultaat:

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

Voorbeeld 2:Rij bevat ALLEEN alfanumerieke gegevens

De volgende code retourneert rijen die alleen alfanumerieke tekens bevatten:

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

Resultaat:

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

Spaties worden als niet-alfanumeriek beschouwd. We kunnen spaties toevoegen door de code als volgt aan te passen:

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

Resultaat:

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

Voorbeeld 3:een alternatieve methode

We kunnen ook de PATINDEX() . gebruiken functie om hetzelfde resultaat te bereiken.

De volgende code retourneert rijen die alleen alfanumerieke tekens bevatten:

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

Resultaat:

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

En met spaties:

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

Resultaat:

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

  1. OASIS-SVN en git gebruiken voor toegang tot broncodecontrole

  2. Maximale uitvoeringstijd in phpMyadmin

  3. Een tabel maken met een externe sleutel in SQL

  4. Hibernate en SQL Server goed laten spelen met VARCHAR en NVARCHAR