IN() के बजाय, एक फ़ील्ड में अल्पविराम से अलग किए गए मानों के बीच खोजने के लिए FIND_IN_SET का उपयोग करें। आइए पहले एक टेबल बनाएं -
mysql> टेबल बनाएं DemoTable -> (-> ListOfValues text -> );क्वेरी ओके, 0 पंक्तियाँ प्रभावित (0.56 सेकंड)
इंसर्ट कमांड का उपयोग करके टेबल में कुछ रिकॉर्ड डालें -
mysql> डेमोटेबल मानों में डालें('10|20|30|40|50|60|100');क्वेरी ठीक है, 1 पंक्ति प्रभावित (0.18 सेकंड)
चयन कथन का उपयोग करके तालिका से सभी रिकॉर्ड प्रदर्शित करें -
mysql> डेमोटेबल से *चुनें;
यह निम्नलिखित आउटपुट देगा -
<पूर्व>+--------------------------+| ListOfValues |+--------------------------+| 10|20|30|40|50|60|100 |+--------------------------+1 पंक्ति सेट में (0.00 सेकंड)एक फ़ील्ड में अल्पविराम से अलग किए गए मानों के बीच खोज करने के लिए क्वेरी निम्नलिखित है -
mysql> DemoTable से FIND_IN_SET(100, replace(ListOfValues,'|',',')) चुनें;
यह निम्नलिखित आउटपुट देगा -
<पूर्व>+------------------------------------------ ---+| FIND_IN_SET(100, बदलें(ListOfValues,'|',',')) |+----------------------------- -------------------+| 7 |+-------------------------------------------------------- --+1 पंक्ति में सेट (0.04 सेकंड)