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

MySQL में LOCATE () फ़ंक्शन कैसे काम करता है

MySQL में, LOCATE() फ़ंक्शन एक स्ट्रिंग के भीतर एक सबस्ट्रिंग की स्थिति देता है। अधिक विशेष रूप से, यह स्ट्रिंग के भीतर पहली घटना की स्थिति देता है, या किसी दिए गए प्रारंभिक बिंदु के बाद पहली घटना देता है।

सिंटैक्स

इसका उपयोग निम्न में से किसी भी तरीके से किया जा सकता है:

LOCATE(substr,str)
LOCATE(substr,str,pos)

जहां substr पता लगाने के लिए सबस्ट्रिंग है, और str खोजने के लिए स्ट्रिंग है।

दूसरे सिंटैक्स का उपयोग करते समय, pos खोज शुरू करने की स्थिति है।

उदाहरण 1 - पहला सिंटैक्स

यहां पहले सिंटैक्स का उपयोग करने वाला एक उदाहरण दिया गया है:

SELECT LOCATE('cat', 'One cat jumped over the other cat') AS Result;

परिणाम:

+--------+
| Result |
+--------+
|      5 |
+--------+

उदाहरण 2 - दूसरा सिंटैक्स

यहां एक उदाहरण दिया गया है जहां हम खोज शुरू करने के लिए एक प्रारंभिक स्थिति निर्दिष्ट करते हैं:

SELECT LOCATE('cat', 'One cat jumped over the other cat', 6) AS Result;

परिणाम:

+--------+
| Result |
+--------+
|     31 |
+--------+

इस मामले में, cat . की पहली घटना स्थिति 5 से शुरू होता है, लेकिन मैंने खोज को स्थिति 6 पर शुरू करने के लिए निर्दिष्ट किया है। इसलिए, उस स्ट्रिंग की अगली घटना की स्थिति वह थी जो लौटा दी गई थी।

ध्यान दें कि, हालांकि खोज स्थिति 6 पर शुरू हुई, फिर भी फ़ंक्शन स्ट्रिंग के भीतर सबस्ट्रिंग की स्थिति लौटाता है - प्रारंभ स्थिति से नहीं।

इसे स्पष्ट करने में सहायता के लिए यहां एक और उदाहरण दिया गया है।

SELECT 
  LOCATE('c', 'a b c', 1) AS 'Result 1',
  LOCATE('c', 'a b c', 2) AS 'Result 2',
  LOCATE('c', 'a b c', 4) AS 'Result 3';

परिणाम:

+----------+----------+----------+
| Result 1 | Result 2 | Result 3 |
+----------+----------+----------+
|        5 |        5 |        5 |
+----------+----------+----------+

परिणाम वही होता है जहां हम खोजना शुरू करते हैं।

उदाहरण 3 - किसी शब्द के भाग का पता लगाना

सबस्ट्रिंग एक लंबे शब्द का हिस्सा हो सकता है:

SELECT LOCATE('sing', 'Increasingly') AS Result;

परिणाम:

+--------+
| Result |
+--------+
|      7 |
+--------+

वास्तव में, इसके लिए एक शब्द होने की कोई आवश्यकता नहीं है (आखिरकार, हम केवल एक स्ट्रिंग खोज रहे हैं):

SELECT 
  LOCATE('z23!#', 'u_4, z23!#') AS 'Result 1',
  LOCATE(' ', 'a b c') AS 'Result 2',
  LOCATE(',', 'cat, dog, bird') AS 'Result 3';

परिणाम:

+----------+----------+----------+
| Result 1 | Result 2 | Result 3 |
+----------+----------+----------+
|        6 |        2 |        4 |
+----------+----------+----------+

उदाहरण 4 - कोई मिलान नहीं

अगर सबस्ट्रिंग नहीं मिलती है, तो 0 लौटा दिया गया है:

SELECT LOCATE('Bat', 'Increasingly') AS Result;

परिणाम:

+--------+
| Result |
+--------+
|      0 |
+--------+

उदाहरण 5 - केस संवेदनशीलता

यह फ़ंक्शन मल्टीबाइट सुरक्षित है, और केवल केस-संवेदी है यदि कम से कम एक तर्क एक बाइनरी स्ट्रिंग है।

इसलिए निम्नलिखित गैर-बाइनरी स्ट्रिंग्स पर काम करता है, भले ही मामला मेल नहीं खाता:

SELECT LOCATE('Sing', 'Increasingly') AS Result;

परिणाम:

+--------+
| Result |
+--------+
|      7 |
+--------+

लेकिन अगर हम बाइनरी स्ट्रिंग का उपयोग करते हैं, तो ऐसा होता है:

SET @str = BINARY 'Increasingly'; 
SELECT LOCATE('Sing', @str) AS Result;

परिणाम:

+--------+
| Result |
+--------+
|      0 |
+--------+

लेकिन निश्चित रूप से, अगर हम इसे बदलते हैं ताकि केस मैच हो जाए, तो हमें एक मैच मिलता है:

SET @str = BINARY 'Increasingly'; 
SELECT LOCATE('sing', @str) AS Result;

परिणाम:

+--------+
| Result |
+--------+
|      7 |
+--------+

उदाहरण 6 - पूर्ण तर्क

यदि कोई तर्क NULL है , नल लौटा दिया गया है:

SELECT 
  LOCATE(NULL, 'Increasingly') a,
  LOCATE('Bat', NULL) b,
  LOCATE('Bat', 'Increasingly', NULL) c;

परिणाम:

+------+------+------+
| a    | b    | c    |
+------+------+------+
| NULL | NULL | NULL |
+------+------+------+

  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. क्या मैं JDBC कनेक्शन पूलिंग का उपयोग कर रहा हूँ?

  3. MySQL आज के बराबर तिथि चुनें

  4. क्या सभी टेक्स्ट-आधारित फ़ील्ड के लिए जेनेरिक वर्चर (255) का उपयोग करने के नुकसान हैं?

  5. वैकल्पिक WHERE पैरामीटर के साथ संग्रहित प्रक्रिया