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

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

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

गैर-अल्फ़ान्यूमेरिक वर्णों में विराम चिह्न वर्ण शामिल हैं जैसे [email protected]#&()–[{}]:;',?/* और प्रतीक जैसे `~$^+=<>“ , साथ ही रिक्त स्थान वर्ण जैसे स्पेस या टैब वर्ण।

नमूना डेटा

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

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 वर्ण वर्ग केवल अल्फ़ान्यूमेरिक वर्ण वाली पंक्तियों को खोजने के लिए, फिर NOT के साथ इसे नकारें ऑपरेटर।

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

परिणाम:

+----------------------+
| c1                   |
+----------------------+
| ()                   |
| [email protected]#&()–[{}]:;',?/*   |
| `~$^+=<>“            |
|                      |
+----------------------+

यदि आपको किसी विशिष्ट वर्ण को बाहर करने की आवश्यकता है, तो आप हमेशा NULLIF() . का उपयोग कर सकते हैं समारोह।

उदाहरण के लिए, अंतिम पंक्ति से खाली स्ट्रिंग को हटा दें:

SELECT c1 FROM t1
WHERE NULLIF(c1, '') NOT REGEXP '[[:alnum:]]';

परिणाम:

+----------------------+
| c1                   |
+----------------------+
| ()                   |
| [email protected]#&()–[{}]:;',?/*   |
| `~$^+=<>“            |
+----------------------+

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

इसे करने का एक और तरीका है कि आप अपने रेगुलर एक्सप्रेशन में वर्णों की एक श्रेणी निर्दिष्ट करें।

उदाहरण:

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

परिणाम:

+----------------------+
| c1                   |
+----------------------+
| ()                   |
| [email protected]#&()–[{}]:;',?/*   |
| `~$^+=<>“            |
|                      |
| é                    |
| É                    |
| ø                    |
+----------------------+

और खाली स्ट्रिंग को हटाने के लिए:

SELECT c1 FROM t1
WHERE NULLIF(c1, '') NOT REGEXP '[A-Za-z0-9]';

परिणाम:

+----------------------+
| c1                   |
+----------------------+
| ()                   |
| [email protected]#&()–[{}]:;',?/*   |
| `~$^+=<>“            |
| é                    |
| É                    |
| ø                    |
+----------------------+

इस मामले में, मेरी बहिष्करण श्रेणी में é . जैसे अक्षरांकीय वर्ण शामिल नहीं थे , É , और ø , और इसलिए आउटपुट गैर-अल्फ़ान्यूमेरिक वर्णों का सही प्रतिनिधित्व नहीं है। उस ने कहा, कम से कम यह विधि आपको उन सटीक वर्णों को निर्दिष्ट करने का विकल्प देती है जिन्हें आप शामिल करना चाहते हैं या परिणाम से बाहर करना चाहते हैं।

REGEXP के विकल्प

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

RLIKE . का उदाहरण :

SELECT c1 FROM t1 
WHERE c1 NOT RLIKE '[[:alnum:]]';

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

SELECT c1 FROM t1 
WHERE NOT 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. उपयोगकर्ता पंजीकरण और ईमेल सत्यापन PHP और MySQL

  2. प्रति उपयोगकर्ता नवीनतम तिथि वाली पंक्ति का चयन करें

  3. PHP - IN क्लॉज सरणी के साथ PDO का उपयोग करना

  4. MySQL में राजस्व की गणना कैसे करें

  5. पीडीओ का उपयोग कर आउट पैरामीटर के साथ संग्रहित प्रक्रिया को कॉल करना