Kategoriler


SON YORUMLAR
Barış Meral
Merhaba ben Barış M. Java SE ve EE geliştiricisiyim. Her türlü seviyeye uygun bitmiş halde olarak, C, C++, C# ve java ile ilgili projeler/ödevler yapılır. bunun yanında Veritabı olarak, MySQL,MSSQLServer, Access ve SQLite etkili kullanıyorum.Web Bölümü için HTML5,CSS3,JavaScript yapılarına hakimim, BackEnd Olarak JSP kullanıyorum her türlü soru için posta adresim: barismeral.net@hotmail.com
Kanaatkar
Yeter Allah bin bereket vesin
Mehmet çalışakn
Amını yirin 5 milyar bana yetmez.
Tamer
Bilgisayar muhendisi aklımda her zaman yer edinmistir ancak gerek ailem gerek cevremdeki insanlar olsun bilgisayar muhendisi cok var okuyup da tamirci olan var gibi bissürü seyler duyuyorum. Hevesim tamamiyle kaciyor
Kaan
Saü bilgisayar mühendisliğinde okuyorum birkaç dersten mezuna kaldım. Java, Android, C++, Web programlama ödevlerinizde yardımcı olabilirim. Geçmişte yaptığım projelerden birkaç tanesini https://github.com/kaan8792 adresinden inceleyebilirsiniz.Not: Whatsapp üzerinden iletişime geçerseniz daha hızlı cevap verebilirim. İletişim için; Mail: kaan8792@gmail.com | Whatsapp: 05428339141
ömer Faruk
bende sayenizde bilgisayar mühendisin olacak kwrarlaştım saynizde teşekkürler
Nesimi
Çok samimi ve gerçekçi.
Can
bende yazı yazıyorum ama gec okunuyor acaba neden kaynaklanıyor. http://www.seslidunyasohbet.com
yazilimci
Java, C/C++, python, perl vs ve bilgisayar müh. derslerinizin ödevleri garantili yapılır, geçen sene olduğu gibi yazilimcialper@gmail.com , yazilimcialper@gmail.com
ihsan bulut
ANDROİD - JAVA - PYTHON - C - C++ GİBİ YAZILIM ALANLARINDA RASPBERRY Pİ - ARDİUNO GİB DONANIM ALANLARINDA HER TÜRLÜ ÖDEV VE PROJE HAZIRLANIR. İLETİŞİM :latifihsanbulut95@gmail.com MAİLLERE EN KISA ZAMANDA DÖNÜŞ YAPILIR.
Ezgi
merhaba, bilgisayar mühendisliği ile ilgilenen insanların zaman aşımına uğramış bilgilerle yanıltılmaması için yazının güncellenmesini öneriyorum. Günümüzde bilgisayar mühendisliği mezunu sayısını oldukça fazla ve popülerliği devam eden, yeni başlayan,çoktan tarihe karışmış teknolojiler var o günden bu güne.
Semih Bey
O kadar ağır bi aşağılık kompleksine kapılmışsın ki, yok "en iyi üniversite öğrencileri nerede,niye başvurmamış" yok "başka okullardaki öğrencileri küçümsersiniz ya" . Ya Allah aşkına Boğaziçi.den mezun olan İtü.den mezun olan adamların senin gibi böyle basit internet sitelerinde ilan vermesini mi bekliyon? Adamlar girip amazon.da, microsoft.ta projede çalışıyorlar, sen gelmiş böyle ucuz bi sitede aklınca onlara laf atmaya çalışıyon. İyi bi üniversite kazanamamışsan bu senin sorunun olum..Kurtul şu kompleksinden.
ömer
bende bilgisayar mühendisi olacam.
Kaan
Saü bilgisayar mühendisliğinde okuyorum birkaç dersten mezuna kaldım. Java, Android, C++, Web programlama ödevlerinizde yardımcı olabilirim. Geçmişte yaptığım projelerden birkaç tanesini https://github.com/kaan8792 adresinden inceleyebilirsiniz.Not: Whatsapp üzerinden iletişime geçerseniz daha hızlı cevap verebilirim. İletişim için; Mail: kaan8792@gmail.com | Whatsapp: 05428339141

Bilgisayar Mühendisleri
Here is the website inspired me to use 
it as a guide when I tried to define 
myself as an engineer candidate a few 
years ago. It really helped me to work
 and study feeling in confidence with 
being on the right way. I suggest this 
website to whom it may direct her/his 
to find the right career path. It 
includes many articles varies from 
real life experiences to detailed 
software engineering issues. But the 
most dignified parts for me are the 
articles in general and career titles.
Son okunan makaleler:
Oracle - Indexler Hakkında detaylı bilgi - 2
Patlaklar ordusuna katılacaklara 12 altın öğüt.
Beyond Unit Testing - Yazılım nasıl test edilmelidir
Database programlama...
Bilgisayar mühendisliğinde okuyan öğrencilere tavsiyeler
Java Dersleri 1: İlk Bakışta JSP (Java Server Pages)
PHP Geliştirme Ortamı - Zend Studio
Introduction to making multithreaded VB.NET Apps
Bilgisayar mühendisliğinde okuyan öğrencilere tavsiyeler
MODEM ÇEŞİTLERİ
Bilgisayar mühendisliğinde okuyan öğrencilere tavsiyeler
Kim neyi niye seçer? Java mı c# mı? Oracle vs SqlServer?
Bilgisayar mühendisliği öldü?
İSTANBUL İSTANBUL İSTANBUL
Bilgisayar Mühendisi olacaklara üniversite seçme rehberi?
Dünyanın En İyi 500 üniversitesi 2007 Sıralaması Açıklandı
Microsoftda Çalışan Bir Türk ile Yapılmış Röportaj
İşsizlik psikolojisi
2016 ekonomik krizi
NHibernate için Veri Erişim Katmanını Otomatik Oluşturma

Bilgisayar Mühendisleri Portalı

Oracle - Indexler Hakkında detaylı bilgi - 2

Indeks var ama neden kullanılmıyor ?

Durum 1 : T tablomuzda “x” ve “y” kolonlarımız olsun ve “idx_t(x,y)”  şeklinde de bir indeksimiz oldugunu düşünelim.( concatenated index).Bu index ‘i kullanabilmek için “where” koşulundan sonra bu kolonları :
         “….where x = :X and y = :Y” şeklinde ya da “…where x = :X” şeklinde  , indeksin kullanılmasını sağlamış oluruz.

”…where y=:Y” durumunda ise indeks kullanılmayacaktır.Indeksli kolonlar T(x, y, z) ise indekten faydalanmak için “where” koşulundan sonra aşağıdaki kolon sırası takip edilirse indeks kullanılır :
(x, y, z)
(x,y)
(x)

(x,z), (y,z) gibi kombinasyonlarda indeks kullanılmaz.(Cost Based Optimizer kullanıldıgını düşünüyoruz)Durum 2 : T tablomuzda “x” kolonu üzerinde indeks oldugu düşünelim.
 

select count(*) from T , işleminde indeks üzerinden gitmesini beklerken FTS yapmış oldugunu görebiliriz.Bunun muhtemel sebebi indeks oluşturulan “x” kolonu “NULL” içermesi olabilir.NULL içeren kolon değerleri için indeks oluşturulmayacağını görmüştük.Bu durumda Oracle mantıklı olan FTS yapmayı tercih edecektir.

Durum 3 : select * from T where func(indexed_col) = value  , gibi bir durumda indeks kullanılamaz.Indeks oluşturulan kolonlar için fonksiyon kullanıldıgında indeks işe yaramaz.Çünkü fonksiyonun değerine değil , fonksiyona parametre olan kolon üzerinde indeks vardır.Eğer buna ihtiyaç var ise “function-based index” kullnılmasında fayda var.

Durum 4 :  Bir karakter kolonu indekslediğimizi düşünelim.Aşağıdaki gibi bir sorguda :
select * from T where indexed_col = 5 , indeks kullanılmayacaktır.Çünkü bu sorgu select * from T where to_number(indexed_col) = 5, ile aynıdır.Bu durumuda (Durum 3)’ te açıklamıştık.Bunu genelleyecek olursa implicit olarak yapılan karakter dönüşümlerine engel olunmaz ise indekste kullanılamaz.
Benzer bir durum tarih alanları üzerinde indeks oluşturulduğunda karşımıza çıkar.
 

select * from T where trunc(indexed_date_col) = trunc(sysdate);

indeks TRUNC fonksiyonu sebebi ile yine kullanılamaz.Bu sorgu yerine :
…. indexed_date_col between trunc(sysdate) and trunc(sysdate)plus one mınus one second;
ya da
select * from t where indexed_date_col between trunc(sysdate) and trunc(sysdate) +1 – 1(1*24*60*60)

kullanılmalıdır.Bununla birlikte yukarıdaki 2 yöntemde, değer bir kez hesaplanıp indeks üzerinden gidilirken

“…where trunc(indexed_date_col) = trunc(sysdate);” durumunda ,her satır için trunc(indexed_date_col) hesaplanacaktır.

DURUM 5 : Indeks var ama hala kullanmıyorsam, bunun bir başka sebebi de CBO için gerekli olan istatistikleri toplamamış olmamız olabilir.Bir tablo oluşturulduktan sonra belli zamanlarda ilgili istatistikleri (tablo, kolon, indeksler vs..) toplamamız gerekiyor.Ancak bu sayede CBO en iyi çözümü bulabilir.Indeks buluna bir tabloda indeksli kolon için, tablo küçük iken FTS tercih etmesi  doğal olabilir.Ama tablo büyüdükçe indeks range scan ile daha performanlı sorgu yapılabilir.ancak CBO, buna ancak elinde dogru bilgi olursa karar verebilir.

DURUM 6 : “CBO için gerekli istatistikleri de topladım ama indeks yerine hala FTS yapılıyor “ , boyle bir durumda gercekten dogru olan FTS olabilir.Örneğin 1000 kayıtlı bir tablo da indeksli kolon üzerinden 250 kaydı sorgulamak istediğimde , indekse gidip oradan tabloya erişim yapılacağına dogrudan tabloya gidip FTS yapmak daha az maliyetli olacaktır.Bu tablodaki veri sayısı örneğin 100.000’e ulaştıgında aynı sorgu için FTS yapması gariptir, bakılması gerekir.

Hakkı Oktay
http://hakkioktay.wordpress.com

Bu makaleyi beğendin mi? Yorumunu Yaz!







Sizden Gelen Yorumlar:

Yorum Yazın

(8.2.2012 15:02:26)
nefret ediom oracledan amma ameleleiik daa
%40 %0 %60
Katılıyorum Çekimserim Katılmıyorum



Mehmet Vecdi Sami(8.2.2012 11:32:22)
Merhaba yazı çok yararlı oldu benim açımdan. Teşekkür ederim.
%75 %0 %25
Katılıyorum Çekimserim Katılmıyorum



1(9.8.2010 09:32:10)
1
%30 %30 %40
Katılıyorum Çekimserim Katılmıyorum






Copyright© 2001-2019. Bilgisayar Mühendisleri Portalı | Bütün hakları saklıdır.