Kategoriler


SON YORUMLAR
Kaan çok eziksin
bsg. yazılımdan anlıyorsan bir işe gir.
İREM
Veri yapıları sınavım var..sınav süresi 30dk ve test..Veri yapılarında bilgili biri ücret karşılığında yardımcı olabilirse çok mutlu olurum..
Eray
29.8.2020 tarihli telefon numaram ile yaptığım yorum, ÖZEL DERS vermek, konu anlatımı yapmak veya freelancer olarak yazılım projelerinde yazılımcı olarak çalışmak içindir. Ödev yaptırmak, sınava girmek gibi isteklere geri dönüş yapmıyorum.
Tatar Ramazan
CLASS (Inheritance, abstract, interface, static) Kurallar: 1- Abstract ve interface classlarda new ile obje oluşturulamaz. Bu kural static sınıflar için de geçerlidir. 2- Statik metotlardan yalnızca statik değişken ve metotlar çağırılır. 3- Sınıfın tüm objeleri statik alanın aynı değerini paylaşır. 4- Sınıftan her obje oluştuğunda statik değişken değeri sıfırlanmaz kaldığı yerden devam eder. 5- Statik alana sınıftan obje oluşturmadan direk ulaşılabilir. 6- Statik değişken her zaman bir değere sahiptir. Nümerik değerler için değer atanmadıysa değeri sıfırdır. 7- Virtual metod, abstract ya da static olamaz. 8- Bir metod ya da properties override edilirken tipi değiştirilmez. 9- Türetilen sınıfta metod override edilmemişse ana sınıftaki içerik geçerli olur. 10- Bir interface uygulayan metod public olmalıdır. 11- Static metod abstract, virtual, override olamaz. 12- Properties?ler abstract ya da virtual olabilir. 13- Türetilen sınıf ana sınıftaki tüm abstract metodları uygulamazsa o da abstract olmalıdır. 14- Abstract metod içeren sınıf da abstract olmalı. 15- Abstract metod otomatikman virtual olur. 16- Türetilen sınıf abstract classtaki tüm metodları uygulamalıdır. 17- Virtual metod birden fazla türetilen sınıfta yeniden tanımlanabilir. 18- Bir sınıf birden fazla interface?i aralarına virgül konularak kullanabilir. 19- Interface tek başına hiçbir uygulama sağlamaz. 20- Abstract metod gövde içermez ve ana sınıf tarafından uygulanamaz. 21- Abstract sınıf içinde statik ya da virtual metod tanımlanabilir. 22- Bir interface metod uygulanırken public değilse başına tanımlandığı interface koyulur. 23- Protected tanımlanan field?a sadece türev sınıf içinden erişilir. 24- Fields (alanlar) virtual ya da abstract olamaz. 25- Interface?ler fields içermez. Properties içerebilir. 26- Bir constructor base ile miras alıyorsa hem aldığı mirası hem kendi içindekini uygular. İçi boşsa yalnızca kalıtım aldığını uygular. Miras alırken de derived (türetilen) classtaki parametre değerini esas alır. 27- Interface metod implemente edilirken override yazılmaz. Override virtual ya da abstract metodlar uygulanırken kullanılır.
World
Hello PIO
PIO
hello world
Tatar Ramazan
2009-10 yıllarında millet maaşını yazardı yüksek miktarlar alırlardı şimdi kimse yazmıyor zavallılar sürünüyorlar. Yanlışsam, durumunuz iyiyse çıkın yanlışlayın beni. Az bir kısmınız mutlu olacak diğerleri kıvransın dursun.
Tatar Ramazan
çok para bayılacaklar osuracaklar, sıçacaklar size zort zort zort...muhahah, puahahah...
tatminsiz
10.000 tl den aşağı çalışmam.

java ve c# ı yalayıp yuttum mssql oracle pl sql ibm db2 biliyorum. projeler yaptım kaç para alcam?
memnun
Muhasebe bölümünden bilişime geçtim 2 ay geride kaldım şimdi geri muhasebeye nakîl verdim ama bu parayı duyunca çallşmaya başladım
muhendis
Eskidendi o çok eskiden..mühendisler artık aç..4 yıllık mühendisim aldığım ücret 5000 tl...
cengiz
Ben de bilmiyorum faidesini...
orhon
ilk önce sql sonra t-sql

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 - Cluster Kavramı (Clustering)
TEKRAR
Bilgisayar Mühendisleri Kaç Para Alır?
Bilgisayar Mühendisleri Kaç Para Alır?
Motivasyona inanmıyorum!
Askerlik ve Bilgisayar Mühendisliği
Gül'den gençlere öğütler: Boşa zaman geçirmeyin
Bilgisayar Mühendisi olacaklara üniversite seçme rehberi?
Bilgisayar Mühendisi olacaklara üniversite seçme rehberi?
Bilgisayar Mühendisleri Kaç Para Alır?
ASP.NET 2.0 - New Features
İşsizlik psikolojisi
Windows Workflow Foundation'a Giriş
Bilgisayar Mühendisleri Kaç Para Alır?
ASP.NET ile GIS Uygulamaları
Bilgisayar Mühendisleri Kaç Para Alır?
Transact-SQL - T-SQL - SQL NEDİR?
Bilgisayar Mühendisleri Kaç Para Alır?
İSTANBUL İSTANBUL İSTANBUL
Bilgisayar Mühendisleri Kaç Para Alır?

Bilgisayar Mühendisleri Portalı

Oracle - Cluster Kavramı (Clustering)

“Kümeleme,bir araya getirme” seklinde Türkçe söyleyebilecegimiz Clustering kavrami veritabani açisindan “verileri bir arada tutma, kümeleme” anlaminda kullanilabilir.

Oracle bu islemi 2 yolla yapar :
i)  Index Cluster
ii) Hash Cluster

Her ikisinide olusturmak için öncelikle elimize bir ”cluster” olmalidir.Varsayilan olarak olusan cluster bir “index cluster”’dir.

i) Index Cluster : Bir ya da daha fazla tabloda bulunan birbiri ile dogrudan iliskili  satirlari ayni segmentte tutan yapidir.Önceden “join” yapilmis veriler olarak da düsünülebilir.Bu durumda ilgili kolonlar ile yapilacak bir sorgu daha performansli olacaktir.

CREATE CLUSTER sc_person (person_id NUMBER(10)) SIZE 512;

“sc_person” isminde bir cluster olusturduk.Sonra CREATE INDEX idx_personnel ON CLUSTER sc_person;   ile  “sc_person” cluster’’i üzerinde bir index cluster olusturmus olduk.

Peki bunu nasil kullanacagiz.Örnegimize bakalim :

CREATE TABLE person (
   person_id   NUMBER(10),
   first_name  VARCHAR2(25),
   last_name   VARCHAR2(25) NOT NULL,
   active_flag VARCHAR2(1) NOT NULL)
CLUSTER sc_person (person_id);
CREATE TABLE invoice (
   person_id NUMBER(10),
   inv_id    NUMBER(10),
   inv_item  VARCHAR2(25) NOT NULL,
   inv_date  DATE NOT NULL)


CLUSTER sc_person (person_id);Bu tablolar olustugunda elimizde “person_id” alanina göre olusturulmus ve sanki her 2 tablo bu alan gore onceden join edilmis ve cikan sonuç kümesi bir arada fiziksel olarak tutuluyor seklinde bir yapi elde edilmis olur.
 
Anlasilacagi üzere index cluster olusturulan alan tablo ya da tablolar arasinda sık kullanilan ortak bir alan ise bu kullanim uygun olmaktadir.Ama bu avantajinin yaninda bir takim dezavantajlari da belirtmekte fayda var.Örnegin FTS(FullTableScan) olacak olursa daha cok zaman alacaktir.Insert islemi normalden daha fazla is yükü getireceginden yavas olacaktir.
ii) Hash Clusters : Hash bilindigi üzere verilen bir parametreye karsilik anahtar(key) üretir.Hash Clusterda da bu sekilde.Verilen bir “cluster key” degerine karsilik olusan anahtar degeri verinin  tutuldugu adresi vermektedir. (Ayni “hash key” degerine sahip satirlar birarada tutulur.)Baska bir degisle elinizde anahtar deger var ise dogrudan ilgili veriye tek I/O ile ulasmak mümkün.Normal bir indekste ise “leaf block” seviyesine inebilmek için birkaç I/O yapmak gerekiyor.

 

Her ne kadar kullanisli bir yapi olsa da özellikle SIZE ve HASHKEYS parametreleri düzgün set edilmedigi zaman performans olarak basinizi agritabilir.SIZE “hash key” degerine karsilik gelebilecek satirlarin tutacagi toplam alan miktarini, HASHKEYS ise tabloda tutulacak toplam kayit adedini ifade eder ve kendisinden sonra gelen en küçük asal sayi olarak Oracle tarafindan yeniden belirlenir.

CREATE CLUSTER trial_cluster (trialno NUMBER(5,0))
HASH IS trialno HASHKEYS 150;
CREATE TABLE trial (trialno NUMBER(5,0) PRIMARY KEY,   …) 
CLUSTER trial_cluster (trialno);

Yukarida once “trial_cluster” adinda bir hash cluster olusturduk.Daha sonra “trial” tablosunda “cluster key” alani olarak “trialno” alanini gösterdik.Oracle HASHKEY olarak 157 degerini kullacaktir.”trialno” alani bir “cluster key”’dir ve Hash fonksiyonuna gönderilerek bir “hash key” üretilir.

HASHKEY degeri çok fazla verilirse hash cluster seyrek olarak dolacaktir ve FTS performansi düsecektir.Eger az verilirse de ayni degeri alan pek çok “cluster key” degeri olacaktir.Bu da yeni bloklarin kullanilmasi ve bu bloklarin birbirine baglanmasi gerekliligine yol açacaktir.Bu da daha fazla I/O ya neden olacaktir.“Cluster Key” olarak  PrimaryKey alani kullanilmasi uygundur.Çünkü “Hash Key”  üreten fonksiyona her seferinde farkli bir deger gönderileceginden “hash key” in tekil olma olasiligi artacaktir.Oracle ‘in “Hash Key” üreten fonksiyonu çogu kosulda güzel çalismaktadir.

Ancak PL/SQL ile kullanicida kendi Hash Key fonksiyonunu yazabilir.Her bir “Hash Key” degeri için ayni miktarda alan tutulmaktadir.örnegin hash key “101” için 4 adet satir alani ayrilmis ise “109” hash key degeri için yine 4 adet satir alani ayrilmistir.

SIZE ve HASHKEY parametrelerinin hesaplanmasi ile ilgili açiklama ve örnekleri asagidaki linkten bulabilirsiniz :

http://download-east.oracle.com/docs/cd/B19306_01/server.102/b14231/hash.htm

Hash Cluster özellikle eşitlik koşuluna uygun verileri almak için kullanılmalıdır. Bunun dısındaki koşullarda tercih edilmemelidir.Boyut olarak sürekli değişen değilde değişmeyecek olan tablolar için uygundur.Aksi halde zaman zaman cluster tekrar oluşturulmalıdır(rebuild).Ayrıca Hash Clusters,FTS yapmak için uygun değildir.

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

Bu makaleyi beğendin mi? Yorumunu Yaz!







Sizden Gelen Yorumlar:

Yorum Yazın

vcv(8.7.2015 23:42:50)
cvcv
%0 %0 %0
Katılıyorum Çekimserim Katılmıyorum






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