Numerik karakter almasını istediğimiz bir kolon içinde alfanumerik karakterlerin atılmış olması durumu her zaman baş ağrısına sebep olur. Veritabanını yanlış tasarlanmasından dolayı bu tür sorunlarla her zaman karşılabiliyoruz. Bu durumdada join işlemlerimizde veya metematiksel işlemlerde hata alırız.
Alfanumerik değerler bulunduran bir kolon içindeki alfanumerik karakterleri temizlemek için sql serverda bir kaç farklı method kullanabiliriz. Bu makalemizde bu örneklerden 2 tanesini paylaşacağım.
İlk olarak karakterin ascii değerini veren ASCII fonksiyonunu kullanarak bir değişkendeki alfanumerik karakerleri temizleyeceğiz.
ASCII fonksiyonu tek bir parametre alır ve içine yazılan varchar değerin ilk karakterine ait ASCII değeri verir. A-Z arasındaki ascii değerlerin dışında kalan karakterleri temizlediğimiz zaman değeri sadece numerik karakterlerden oluşmuş hale getireceğiz.
Alfanumerik değerleri ASCII fonksiyonunu kullanarak temizleme:
declare @metin varchar(100)
set @metin = 'Yaz1234Mut987'
declare @uzunluk int= len(@metin)
declare @i int=1
declare @temizMetin varchar(max)
set @temizMetin = '' --yeni degeri atayacağımız metin
while @i<=@uzunluk
begin
if ASCII(SUBSTRING(@metin,@i,1))>=48 and ASCII(SUBSTRING(@metin,@i,1))<=57
--48 ile 57 arasında ascii değeri olan karakterler 0-9 aralığıdır.
begin
set @temizMetin=@temizMetin+SUBSTRING(@metin,@i,1)
-- 0-9 arasındaki değerleri sırası ile yeni metne ekliyoruz.
--böylece 0-9 arasında olmayan karakterleri almamış oluyoruz.
end
set @i=@i+1
end
print @temizMetin
Yukarıdaki sogu sonucunda 'Yaz1234Mut987' olarak verilen string değer '1234987' olarak çıkar. Böylece alfanumerik karakterleri temizlemik olduk.
Alfanumerik Karakterlerin ASCII kodları (A-Z ve a-z):
asciiDegeri | karakter | asciiDegeri | karakter |
---|---|---|---|
65 | A | 94 | ^ |
66 | B | 95 | _ |
67 | C | 96 | ` |
68 | D | 97 | a |
69 | E | 98 | b |
70 | F | 99 | c |
71 | G | 100 | d |
72 | H | 101 | e |
73 | I | 102 | f |
74 | J | 103 | g |
75 | K | 104 | h |
76 | L | 105 | i |
77 | M | 106 | j |
78 | N | 107 | k |
79 | O | 108 | l |
80 | P | 109 | m |
81 | Q | 110 | n |
82 | R | 111 | o |
83 | S | 112 | p |
84 | T | 113 | q |
85 | U | 114 | r |
86 | V | 115 | s |
87 | W | 116 | t |
88 | X | 117 | u |
89 | Y | 118 | v |
90 | Z | 119 | w |
91 | [ | 120 | x |
92 | \ | 121 | y |
93 | ] | 122 | z |
declare @Table Table (asciiDegeri int,karakter char)
declare @asciiDeger int
set @asciiDeger = 65
while @asciiDeger <= 122
begin
insert into @Table values(@asciiDeger ,char(@asciiDeger))
set @asciiDeger = @asciiDeger+1
end
select * from @Table
Şimdi Alfanumerik Karakterleri temizlemenin diğer bir yöntemine bakalım. Bu metodda ise PARHINDEX ve STUFF fonksiyonlarını kullanacağız. PATHINDEX fonksiyonu, bir metin içinde istediğimiz paterne uyan bir değer varsa bunun indexini döndürür. STUFF ise bir metin içinde belirli bir indexdeki değeri başka bir değerle değiştirmek için kullanılır.
DECLARE @metin VARCHAR(32)
DECLARE @i int
SELECT @metin = '9$%sabri45623 *6%}@~:'
SELECT @i = PATINDEX('%[^0-9]%', @metin)
WHILE @i > 0
BEGIN
SELECT @metin = STUFF(@metin, @i, 1, '')
SELECT @i = PATINDEX('%[^0-9]%', @metin)
--[^0-9] ifadesi 0 ile 9 arasında olmayan anlamına geliyor.
END
SELECT @metin
Yukarıdaki sorgu sonucunda '9$%sabri45623 *6%}@~:' ifadesi '9456236' olarak alfanumerik karakterlerden temizlenmiş oldu.
Hiç yorum yok:
Yorum Gönder