SQL सर्वर में, आप T-SQL का उपयोग कर सकते हैं CHARINDEX()
किसी अन्य वर्ण व्यंजक के भीतर किसी वर्ण व्यंजक की आरंभिक स्थिति खोजने के लिए कार्य करता है।
आप दोनों चरित्र भाव को तर्क के रूप में प्रदान करते हैं। खोज शुरू करने के लिए स्थिति निर्दिष्ट करने के लिए आप एक वैकल्पिक तर्क भी प्रदान कर सकते हैं।
सिंटैक्स
वाक्य रचना इस प्रकार है:
CHARINDEX ( expressionToFind , expressionToSearch [ , start_location ] )
जहां expressionToFind वह अभिव्यक्ति है जिसे आप अन्य स्ट्रिंग में खोजना चाहते हैं, और expressionToSearch दूसरी स्ट्रिंग है। वैकल्पिक start_location expressionToSearch . के भीतर स्थिति निर्दिष्ट करने के लिए इस्तेमाल किया जा सकता है जिसके लिए खोजना शुरू करना है।
ध्यान दें कि केवल पहली घटना की स्थिति लौटा दी जाती है।
उदाहरण
यहां एक उदाहरण दिया गया है:
SELECT CHARINDEX('Bob', 'Bob likes beer. Bob also likes beef.') AS Result;
परिणाम:
+----------+ | Result | |----------| | 1 | +----------+
इस उदाहरण में, पहला तर्क Bob
है , जिसका अर्थ है कि हम Bob
. के लिए दूसरा तर्क खोज रहे हैं . परिणाम 1 है क्योंकि यह वह स्थिति है जहां Bob
पहले दूसरे तर्क में प्रकट होता है।
आप यह भी देख सकते हैं कि Bob
वास्तव में स्ट्रिंग में दो बार दिखाई देता है, लेकिन केवल पहले मैच की स्थिति लौटा दी जाती है।
कोई मिलान नहीं
यदि दूसरे तर्क में Bob
नहीं था नतीजा 0
होता ।
SELECT CHARINDEX('Bob', 'Kate likes beer. Kate also likes beef.') AS Result;
परिणाम:
+----------+ | Result | |----------| | 0 | +----------+
प्रारंभिक स्थिति निर्दिष्ट करना
आप (वैकल्पिक रूप से) खोज के लिए प्रारंभिक स्थिति निर्दिष्ट कर सकते हैं। इसका मतलब है कि SQL सर्वर उस प्रारंभिक स्थिति से पहले आने वाली किसी भी घटना को छोड़ देगा। हालांकि, परिणाम अभी भी पूरी स्ट्रिंग के भीतर इसकी स्थिति के आधार पर रिपोर्ट किए जाते हैं (आपके चुने हुए प्रारंभिक स्थान से नहीं)।
प्रदर्शित करने के लिए यहां एक उदाहरण दिया गया है:
SELECT CHARINDEX('Bob', 'Bob likes beer. Bob also likes beef.', 16) AS Result;
परिणाम:
+----------+ | Result | |----------| | 17 | +----------+
इस उदाहरण में हम स्थिति 16 पर खोज करना शुरू करते हैं (जो दूसरे Bob
से पहले का स्थान होता है। ) नतीजा यह है कि Bob
. की पहली घटना छोड़ दिया जाता है, और दूसरे की स्थिति वापस कर दी जाती है। और हम देख सकते हैं कि इसकी स्थिति स्ट्रिंग की शुरुआत से 17 वर्णों की है (भले ही यह केवल एक वर्ण है जहाँ से हमने खोजना शुरू किया है)।
केस-सेंसिटिविटी
आप COLLATE
. जोड़कर स्पष्ट रूप से केस-संवेदी खोज कर सकते हैं अपने SELECT
. का खंड कथन:
यहां एक उदाहरण दिया गया है जिसमें केस-संवेदी खोज और केस-संवेदी खोज शामिल हैं:
SELECT CHARINDEX('Beer', 'Bob likes beer.' COLLATE Latin1_General_CS_AS) AS 'Case-Sensitive', CHARINDEX('Beer', 'Bob likes beer.' COLLATE Latin1_General_CI_AS) AS 'Case-Insensitive';
परिणाम:
+------------------+--------------------+ | Case-Sensitive | Case-Insensitive | |------------------+--------------------| | 0 | 11 | +------------------+--------------------+
पहला केस-संवेदी है क्योंकि _CS
(संयोजन में) केस-सेंसिटिव के लिए खड़ा है। दूसरा केस-संवेदी है क्योंकि _CI
केस-असंवेदनशील के लिए खड़ा है।