Mysql
 sql >> डेटाबेस >  >> RDS >> Mysql

पंक्तियों को वापस करने के 2 तरीके जिनमें MySQL में अल्फ़ान्यूमेरिक वर्ण होते हैं

नीचे उन पंक्तियों को खोजने के लिए दो विकल्प दिए गए हैं जिनमें MySQL में अल्फ़ान्यूमेरिक वर्ण हैं।

अक्षरांकीय वर्ण, वर्णानुक्रमिक वर्ण और संख्यात्मक वर्ण होते हैं।

नमूना डेटा

हम अपने उदाहरणों के लिए निम्नलिखित डेटा का उपयोग करेंगे:

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;

परिणाम:

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

विकल्प 1:[:alnum:] से तुलना करें

हम MySQL के REGEXP . का उपयोग कर सकते हैं ऑपरेटर हमारे कॉलम की तुलना रेगुलर एक्सप्रेशन से करने के लिए।

MySQL की नियमित अभिव्यक्ति क्षमता में POSIX वर्ण वर्गों के लिए समर्थन शामिल है। इसलिए, हम [:alnum:] . का उपयोग कर सकते हैं अल्फ़ान्यूमेरिक वर्णों वाली पंक्तियों को खोजने के लिए हमारे नियमित अभिव्यक्तियों में POSIX वर्ण वर्ग।

SELECT c1 FROM t1 
WHERE c1 REGEXP '^[[:alnum:]]+$';

परिणाम:

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

यह केवल उन पंक्तियों को लौटाता है जिनमें अल्फ़ान्यूमेरिक वर्णों के अलावा कुछ नहीं होता है। यदि किसी पंक्ति में अल्फ़ान्यूमेरिक और गैर-अल्फ़ान्यूमेरिक दोनों वर्ण हैं, तो उसे वापस नहीं किया जाता है।

स्पेस कैरेक्टर को गैर-अल्फ़ान्यूमेरिक माना जाता है, और इसलिए यदि हम रिक्त स्थान शामिल करना चाहते हैं, तो हम यह कर सकते हैं:

SELECT c1 FROM t1 
WHERE c1 REGEXP '^[[:alnum:] ]+$';

परिणाम:

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

उन सभी पंक्तियों को वापस करने के लिए जिनमें शामिल हैं अल्फ़ान्यूमेरिक वर्ण (भले ही पंक्ति में गैर-अल्फ़ान्यूमेरिक वर्ण भी हों), हम यह कर सकते हैं:

SELECT c1 FROM t1 
WHERE c1 REGEXP '[[:alnum:]]';

परिणाम:

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

विकल्प 2:वर्णों की श्रेणी निर्दिष्ट करें

ऐसा करने का एक और तरीका नियमित अभिव्यक्ति प्रदान करना है जो वर्णों की एक श्रृंखला प्रदान करता है। हम अब भी REGEXP . का उपयोग कर सकते हैं ऐसा करने के लिए ऑपरेटर।

उदाहरण:

SELECT c1 FROM t1 
WHERE c1 REGEXP '^[A-Za-z0-9]+$';

परिणाम:

+-------+
| c1    |
+-------+
| Music |
| 007   |
+-------+

यह हमारे पहले उदाहरण की तुलना में कम पंक्तियाँ लौटाता है। ऐसा इसलिए है क्योंकि मैंने é . शामिल नहीं किया था , É , या ø मेरी सीमा में वर्ण, और इसलिए उन वर्णों वाली किसी भी पंक्ति को आउटपुट से बाहर रखा गया है।

इसलिए, यदि आप गलती से उन वर्णों को बाहर कर देते हैं जिन्हें आपको शामिल करना चाहिए, तो इस पद्धति का उपयोग करते समय आपको सावधान रहने की आवश्यकता होगी।

हालांकि, इस सीमा को ध्यान में रखते हुए, हम इस तरह के रिक्त स्थान शामिल कर सकते हैं:

SELECT c1 FROM t1 
WHERE c1 REGEXP '^[A-Za-z0-9 ]+$';

परिणाम:

+------------+
| c1         |
+------------+
| Music      |
| Live Music |
| Player 456 |
| 007        |
+------------+

और हम निम्नलिखित का उपयोग उन सभी पंक्तियों को शामिल करने के लिए कर सकते हैं जिनमें शामिल हैं हमारी श्रेणी के वर्ण (भले ही उनमें इस श्रेणी के बाहर के वर्ण भी हों):

SELECT c1 FROM t1 
WHERE c1 REGEXP '[A-Za-z0-9]';

परिणाम:

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

REGEXP के विकल्प

MySQL में, RLIKE और REGXP ऑपरेटर REGEXP_LIKE() . के पर्यायवाची हैं . इसलिए, हम पिछले किसी भी उदाहरण को RLIKE . से बदल सकते हैं या REGEXP_LIKE()

RLIKE . का उदाहरण :

SELECT c1 FROM t1 
WHERE c1 RLIKE '^[[:alnum:]]+$';

REGEXP_LIKE() . का उदाहरण :

SELECT c1 FROM t1 
WHERE REGEXP_LIKE(c1, '^[[:alnum:]]+$');

  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. MySQL में पंक्तियों को हटाने के लिए क्वेरी हटाएं

  2. सॉकेट '/var/mysql/mysql.sock' के माध्यम से स्थानीय MySQL सर्वर से कनेक्ट नहीं हो सकता (38)

  3. Generate_series () MySQL में समतुल्य

  4. व्यवहार द्वारा समूह जब चयन खंड में कोई समग्र कार्य मौजूद नहीं है

  5. रिलेशनल डेटाबेस में IPv6-संगत पते को कैसे स्टोर करें