CHECK बाधा ###। ###। #### पैटर्न मैच लागू करने के लिए


11

मैं एक चेक बाधा है कि एक बहु भाग कोड के लिए इस regex पैटर्न लागू करना चाहते हैं:

^\d{3}\.\d{3}\.\d{4}$

... तीन नंबर, एक पीरियड, तीन नंबर, एक पीरियड, चार नंबर।

क्या मुझे पैटर्न मिलान को लागू करने के लिए सीएलआर फ़ंक्शन बनाने की आवश्यकता है, और क्या सीएलआर फ़ंक्शन को डीडीएल में संदर्भित किया जा सकता है?

क्या किसी अन्य तरीके से पैटर्न को लागू करने का एक तरीका है, का उपयोग करना LIKE?

जवाबों:


16

आपके प्रश्न में regex पूरी तरह से अस्पष्ट नहीं है

अधिकांश फ्लेवर में जो यूनिकोड का समर्थन करते हैं, \ d में सभी लिपियों के सभी अंक शामिल हैं। उल्लेखनीय अपवाद जावा, जावास्क्रिप्ट और पीसीआरई हैं। ये यूनिकोड फ्लेवर केवल \ _ d के साथ ASCII अंकों से मेल खाते हैं।

तो कई स्वादों में यह मेल खाता होगा ١١١.١١١.١١١١(वह पात्र अरबी-इंडिक डिजिट वन होगा )

मैं मान रहा हूं कि आप सिर्फ लैटिन से मेल खाना चाहते हैं 0-9। आप उपयोग कर सकते हैं

DECLARE  @T TABLE
(
Col CHAR(12) CHECK (
                   Col LIKE REPLACE('ddd.ddd.dddd','d','[0-9]') 
                                  COLLATE Latin1_General_100_BIN2
                   )
)

मैं बाइनरी कोलाट क्लॉज का उपयोग कर रहा हूं ताकि चेक को पास न करें ¾¾¾.¾¾¾.¾¾¾¾या 10².10².1000पास न करें ( जैसा कि कुछ कोलाज पर हो सकता है )।

इनमें से कोई भी वांछित सीएलआर रेगेक्स से मेल नहीं खाएगा और हालांकि [0123456789]सीमा सिंटैक्स ( [0-9]) के बजाय सेट सिंटैक्स ( ) का उपयोग करके पहले एक को हल करता है यह अभी भी मिलान निर्भर है कि क्या 2मेल खाता है ²या नहीं।

मैं REPLACEहार्ड-कोडिंग LIKEपैटर्न के बजाय उपयोग कर रहा हूं क्योंकि मुझे यह अधिक पठनीय लगता है कि पैटर्न क्या जाँच रहा है। तीन अंकों को देखना आसान है और एक डॉट को तीन अंकों के बाद दूसरे डॉट को फिर उस प्रारूप में चार अंकों को पार्स करने की तुलना में [0-9][0-9][0-9].[0-9] [0-9][0-9].[0-9][0-9][0-9][0-9]

यह कार्यान्वयन को स्वैप करने में भी आसान बनाता है।

मैं यह तय करता हूं कि आप सीएलआर नियमित अभिव्यक्ति का पूर्ण विकसित शब्दार्थ चाहते हैं, आखिरकार आप '[0-9]'नीचे से ऊपर को बदल सकते हैं (और NCHAR(12)उस स्थिति में स्तंभ को बदल सकते हैं )

'[' +
 /*48-57 Basic Latin*/
N'0-9'+
 /*1632-1641 Arabic-Indic*/
N'٠-٩'+
 /*1776-1785 Extended Arabic-Indic*/
N'۰-۹'+
 /*1984-1993 Nko*/
N'߀-߉'+
 /*2406-2415 Devanagari*/
N'०-९'+
 /*2534-2543 Bengali*/
N'০-৯'+
 /*2662-2671 Gurmukhi*/
N'੦-੯'+
 /*2790-2799 Gujarati*/
N'૦-૯'+
 /*2918-2927 Oriya*/
N'୦-୯'+
 /*3046-3055 Tamil*/
N'௦-௯'+
 /*3174-3183 Telugu*/
N'౦-౯'+
 /*3302-3311 Kannada*/
N'೦-೯'+
 /*3430-3439 Malayalam*/
N'൦-൯'+
 /*3558-3567 Sinhala*/
N'෦-෯'+
 /*3664-3673 Thai*/
N'๐-๙'+
 /*3792-3801 Lao*/
N'໐-໙'+
 /*3872-3881 Tibetan*/
N'༠-༩'+
 /*4160-4169 Myanmar*/
N'၀-၉'+
 /*4240-4249 Myanmar Shan*/
N'႐-႙'+
 /*6112-6121 Khmer*/
N'០-៩'+
 /*6160-6169 Mongolian*/
N'᠐-᠙'+
 /*6470-6479 Limbu*/
N'᥆-᥏'+
 /*6608-6617 New Tai Lue*/
N'᧐-᧙'+
 /*6784-6793 Tai Tham Hora*/
N'᪀-᪉'+
 /*6800-6809 Tai Tham Tham*/
N'᪐-᪙'+
 /*6992-7001 Balinese*/
N'᭐-᭙'+
 /*7088-7097 Sundanese*/
N'᮰-᮹'+
 /*7232-7241 Lepcha*/
N'᱀-᱉'+
 /*7248-7257 Ol Chiki*/
N'᱐-᱙'+
 /*42528-42537 Vai*/
N'꘠-꘩'+
 /*43216-43225 Saurashtra*/
N'꣐-꣙'+
 /*43264-43273 Kayah Li*/
N'꤀-꤉'+
 /*43472-43481 Javanese*/
N'꧐-꧙'+
 /*43504-43513 Myanmar Tai Laing*/
N'꧰-꧹'+
 /*43600-43609 Cham*/
N'꩐-꩙'+
 /*44016-44025 Meetei Mayek*/
N'꯰-꯹'+
 /*65296-65305 Fullwidth*/
N'0-9'+
N']'  COLLATE Latin1_General_100_BIN2
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.