MySQLi - Regexps

आपने MySQLi पैटर्न को मेल खाते हुए देखा है LIKE ...%। MySQLi नियमित अभिव्यक्तियों और के आधार पर एक अन्य प्रकार के पैटर्न मिलान ऑपरेशन का समर्थन करता हैREGEXPऑपरेटर। यदि आप PHP या PERL से अवगत हैं, तो यह समझना आपके लिए बहुत सरल है क्योंकि यह मिलान नियमित स्क्रिप्टिंग के समान है।

निम्नलिखित पैटर्न की तालिका है, जिसका उपयोग किया जा सकता है REGEXP ऑपरेटर।

प्रतिरूप पैटर्न क्या मेल खाता है
^ स्ट्रिंग की शुरुआत
$ स्ट्रिंग का अंत
कोई भी एक पात्र
[...] वर्ग कोष्ठक के बीच सूचीबद्ध कोई भी वर्ण
[^ ...] वर्ग कोष्ठक के बीच कोई वर्ण सूचीबद्ध नहीं है
p1 | p2 | p3 प्रत्यावर्तन; किसी भी पैटर्न p1, P2, या p3 से मेल खाता है
* पूर्ववर्ती तत्व का शून्य या अधिक उदाहरण
+ पूर्ववर्ती तत्व का एक या अधिक उदाहरण
{N} n पूर्ववर्ती तत्व के उदाहरण
{मी, n} पूर्ववर्ती तत्व के n उदाहरणों के माध्यम से मी

उदाहरण

अब उपरोक्त तालिका के आधार पर, आप अपनी आवश्यकताओं को पूरा करने के लिए विभिन्न प्रकार के एसक्यूएल प्रश्नों को लिख सकते हैं। यहाँ, मैं आपकी समझ के लिए कुछ सूचीबद्ध कर रहा हूँ। विचार करें कि हमारे पास एक टेबल है जिसे tutorial_inf कहा जाता है और यह नाम से एक फ़ील्ड है -

'Sa' से शुरू होने वाले सभी नामों को खोजने की क्वेरी

mysql>  SELECT * FROM tutorials_inf WHERE name REGEXP '^sa';

नमूना उत्पादन इस तरह होना चाहिए -

+----+------+
| id | name |
+----+------+
|  1 | sai  |
+----+------+
1 row in set (0.00 sec)

'Ai' के साथ समाप्त होने वाले सभी नामों को खोजने की क्वेरी

mysql> SELECT * FROM tutorials_inf WHERE name REGEXP 'ai$';

नमूना उत्पादन इस तरह होना चाहिए -

+----+------+
| id | name |
+----+------+
|  1 | sai  |
+----+------+
1 row in set (0.00 sec)

सभी नामों को खोजने के लिए क्वेरी, जिसमें 'ए' है

mysql> SELECT * FROM tutorials_inf WHERE name REGEXP 'a';

नमूना उत्पादन इस तरह होना चाहिए -

+----+-------+
| id | name  |
+----+-------+
|  1 | sai   |
|  3 | ram   |
|  4 | johar |
+----+-------+
3 rows in set (0.00 sec)

एक स्वर से शुरू होने वाले सभी नामों को खोजने की क्वेरी

mysql>  SELECT * FROM tutorials_inf WHERE name REGEXP '^[aeiou]';