###. ###. #### kalıp eşleşmesini zorlamak için kısıtlamayı kontrol edin


11

Çok parçalı bir kod için bu normal ifade kalıbı zorlayan bir kontrol kısıtlaması istiyorum:

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

... üç sayı, bir nokta, üç sayı, bir nokta, dört sayı.

Kalıp eşleşmesini zorunlu kılmak için bir CLR işlevi oluşturmam gerekiyor mu ve CLR işlevine DDL'de başvurulabilir mi?

Deseni kullanarak başka bir şekilde zorlamanın bir yolu var mı LIKE?

Yanıtlar:


16

Sorunuzdaki normal ifade tamamen açık değil

Unicode'u destekleyen çoğu aromada, \ d tüm komut dosyalarındaki tüm basamakları içerir. Önemli istisnalar Java, JavaScript ve PCRE'dir. Bu Unicode aromaları yalnızca \ d ile ASCII basamaklarıyla eşleşir.

Bu yüzden birçok lezzette eşleşir ١١١.١١١.١١١١(bu karakter Arapça-Hint Rakamı Biridir )

Sadece latin ile eşleşmek istediğini varsayıyorum 0-9. Kullanabilirsiniz

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

İkili harmanlama yan tümcesi kullanıyorum, bu yüzden ( bazı harmanlamalarda olduğu gibi) çekleri onaylamayın ¾¾¾.¾¾¾.¾¾¾¾veya 10².10².1000geçmeyin .

Ne bu istenen CLR düzenli ifade eşleşecektir ve ayar sözdizimi (kullanarak her ne kadar [0123456789]) yerine aralığı sözdizimi ( [0-9]) birinci bir giderir hala harmanlama olmamasına bağlıdır 2stoktaki ²ya da değil.

Deseni kontrol etmek yerine daha okunabilir bulduğum REPLACEiçin LIKEkalıbı kodlamak yerine kullanıyorum . Üç haneyi ve bir noktayı, ardından üç haneyi başka bir noktayı, ardından bu haldeki dört haneyi ayrıştırmaktan görmek daha kolaydır [0-9][0-9][0-9].[0-9] [0-9][0-9].[0-9][0-9][0-9][0-9].

Ayrıca, uygulamanın değiştirilmesini kolaylaştırır.

CLR normal ifadesinin tam anlambilimsel anlambilimini, her '[0-9]'şeyden önce aşağıya doğru değiştirebileceğinize (ve muhtemelen NCHAR(12)bu durumda sütunu değiştirmeye) karar veriyorsunuz

'[' +
 /*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
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.