27 Haziran 2009 Cumartesi

Açık Portları Görmek

Bilgisayarda açık portları görebilmenin basit bir yolu var Eğer TCP için görecekseniz.çalıştır>cmd açarak

netstat -anop TCP.

Yazmanız yeterli

24 Haziran 2009 Çarşamba

Beta Balığı

Bu Yazılım Geliştirme blogunda nerden çıktı beta balığı muhabbeti diyebiliriniz.
Arada Bir Yazılım işlerinden sıyrılıp kendimize vakit ayırmalıyız diye düşünüyorum.Birde emin tatları çok tezzetli :) sakın he ! şaka tadına falan bakmadım zaten öyle yenilecek falan gibi değiller.
Neyse bir iki resimden sonra çarpıntı Beta Balığı yetiştirme klavuzumuzu okuyabilirsiniz.

Gözlemlerim sonucunda yazacaklarım sizlere bilgi kaynağı olacaktır. Ayrıca belki anlayamadığınız konuları bu yazdığım bilgiler sonucunda daha rahat kavramanızı sağlayacaktır.
Beta balıklarının birçok cinsi olduğuna eminim, hatta bazı duyumlardan ve bazı akvaryumla ilgili sitelerde de bulunan yazıları gördüğümde bu cins çokluğu bana aha fazla inandırıcı geldi. Ülkemizde en bilinen cins Betalar sırasıyla:
1- Betta Splendes
2- Betta Dimidiata
3- Betta Rutilans

Bu üç cinsten de ülkemizde en sık bulunanı ise Betta Splendes tir. Ayrıca bazı yerlerde Beta balıkları “siyam ya da dövüşçü balığı” olarak ta adlandırılabilir. Güney Asya’da Beta balıkları çok değerli olup, bu balıklar için “Beta Dövüş Turnuvaları” bile yapılmaktadır. Bizim ülkemizde nasıl horoz dövüşü varsa Beta balıklarının dövüş mekanı ağırlıklı olarak ta Güney Asya’dır. Beta balıklarının toplandığı yerler ise pirinç tarlalarıdır. Aslında bu balıklar derin olmayan ve hareketsiz, durgun sularda yaşamaktadırlar. Ayrıca bu suların bir bölümü pirinç tarlalarından da geçmektedir ve yavru Betalar veya yumurtalar bu pirinç tarlalarına girmekte; sonuç olarak ta oradan büyüyüp gelişmektedir.
Beta balıkları labirentli balıklardır. Labirent denilen bir organ sonucu; oksijeni çok düşük sularda bile hayatta kalmalarını sağlayan bir organdır. Bu organ sayesinde aynı insanlar gibi doğrudan havadan da oksijen alabilirler. Ürerken de köpük yuva tekniğini kullanırlar.


Bakımı

Beta balıklarının bakımı aslında çok kolay ama bazı kişiler bu olayı çok büyütmektedirler. Beta balıkları kesinlikle fanusta, kavanozda ya da bardakta beslenmez. Çünkü bu balıklar ne kadar geniş alan olursa o kadar dirençli ve güzel görünüm kazanırlar. Beta balıkları için en küçük ideal akvaryum boyutu yükseklik:30cm * genişlik:30cm ebatlarında olmalıdır. İsterseniz bu ebatları kendinizce büyütebilirsiniz.
Akvaryumun içini donatmak içinse bol bitkili olması tercih edilir ama kesinlikle koyulan bitkiler balığın yüzüşünü etkilememelidir. Suyun üstünde duran köksüz su bitkileri ve akvaryumun dibinde çim gibi duran bitkiler bu iş için çok idealdir. Ayrıca Beta akvaryumunda bulunan bitkiler, akvaryum suyunun kirlenmesini geciktirir ve balığa oksijen katkısı sağlar.
Beta akvaryumunun ısısı en az 23°C - 24°C olmalıdır. Mayıs ayından sonra ise ısıtıcınızı kapatıp tekrar Eylül ayının ikinci haftasında tekrar kullanabilirsiniz. ısıtıcınızın 26°C -28°C derecede olması Beta balığınızı kesinlikle öldürmez ama çabuk yaşlandırmaya sebep verir. Böylece balığınızın ömrü kısalır.


Yemleme konusunda ise tavsiyem, canlı yem ya da kaliteli yemlerdir. Canlı yem kullanmanız ilk tavsiyemdir. Eğer sivri sinek ve karınca rahatlıkla bulabilirseniz Beta balığınıza verin, severek tüketirler.
Akvaryumunuzda kesinlikle filtre kullanmayın. Beta balıkları hareketli suyu sevmedikleri için, filtreli bir akvaryumda kolayca stres altına girebilir ve ölümle sonuçlanabilir.
Beta balıkları akvaryum aksesuarlarının içine girip orada kalmayı çok hoşlanırlar. eğer akvaryumunuza mağara veya onların saklanabileceği ufak bir yer yaparsanız çok daha iyi olacaktır. Bazı zamanlar her şeyden uzaklaşıp, kendini stresten uzak tutmak isteyecektir ve akvaryumunuzda bulunan mağara ve oyuklar onlar için bir nevi ilaç olacaktır.
Beta balıklarını başka balıkla beslemeyin. Dişi betalar barışçıldır ancak erkekleri ise çok hırçındır.


Suyun değişimi ise her ay değiştirmek şart değildir. 2 – 3 ay gibi uzun bir süreden sonra su değişimi yapabilirsiz ancak suyu tamamen değiştirmeyip sadece belli bir ( %20) miktar değiştirmeniz tavsiye edilir.

Üretimi

Sağlık dişi ve erkek beta alıp bunları aynı akvaryum içersine koyup, akvaryumun ortasını şeffaf renkte bir cam ile bölünüz. Plastik cam koymayın. Çünkü plastik su içinde bulanık gözüküyor ve balıklar birbirlerini fark edemiyor. Ayrıca dişi için ayrı bir akvaryum daha hazırlayın. Doğumdan sonra dişiyi hazırladığınız akvaryuma koymanız gerekmektedir.
Üretim için kullanacağınız Betanızı üretimden en az 2 hafta önce kaliteli ya da canlı yemlerle beslemeniz önerilir. Çünkü yavru doğumu kaliteli ve dirençli olmaktadır. Ayrıca balık doğumdan sonra çabuk direnç kaybına uğramaz. Dişi ve erkek Betalar pastelimsi renklerde olmalıdır. Böylece daha güzel görünümlü yavrular elde edersiniz.
Akvaryumu ikiye böldüğünüzden itibaren dişi ve erkek Betalar birbirlerini görürler. Bunun sonucunda birbirlerine kur yapmaya başlarlar. Zaten ikisi de tam üreme safhasına geldiği zaman erkek Beta suyun üstüne köpük yuva çalışmasına başlar. Bu köpük yuva benim gözlemlerim sonucunda 1 – 1,5 cm arasında olmaktadır. Suyun yüzeyi adeta minik baloncuklarla dolmaktadır ve çok hoş bir görüntüsü de vardır.
Erkek Beta suyun yüzeyini tamamen köpük yuva ile bitirdiği zaman akvaryumu böldüğünüz canım yanına gelir ve hareket etmeden dişiyi izler. Tabi ki bu olaylar 1 hafta içersinde olmaktadır. Erkek Betaların bazıları 1 gün de köpük yuvayı bitirirken bazıları ise 3-4 gün arasında köpük yuvalarını bitirirler. 1 haftadan sonra dişi ve erkek betalar genellikle çiftleşme isteğinde bulunurlar. Zaten hareketlerinden belli de olmaktadır. Bu durumda dikkat edilmesi gereken en büyük olay, kesinlikle köpük yuvayı bozmadan ortadaki bölme camı kaldırmaktır. Eğer köpük yuvayı bozarsanız erkek Beta bir anlık olayla dişiyi hemen öldürür. Çünkü erkek Betanın o an için üreme konsantrasyonu kaybolmaktadır.


Orta bölme camını kaldırdığınız zaman erkek Beta hemen dişinin yanına gidip, dişiyi belinden kavrayıp yılan gibi sarmaktadır. Bu sarma sonucunda dişiden yumurtalar dökülmektedir. Eğer balık ilk defa yumurtluyorsa 25 veya daha az sayıda yumurta dökebilir. Ancak her doğumdan sonra bu yumurta sayıları fazlalaşır.
Dişi betanın yumurta dökme işi bittikten sonra dişiyi daha önce hazırladığınız temiz bir akvaryuma alınız ve dişiye canlı yem, kaliteli yemler gibi çeşitli yemlerle tekrar eskisi gibi güç kazanmasını sağlayın. Çünkü doğumdan sonra dirençsiz kalma sorunları ortaya çıkıyor. Bu olay gayet normal bir şeydir.
Erkek beta dipteki yumurtaları ağzı ile toplayıp, daha önce kurduğu köpük yuvaların içine teker teker koyar. Kesinlikle yavrularını yemez. Bu olay iç güdüsü tarafından gerçekleştirmektedir. Erkek Beta yavrularıyla birlikte ilk 3-4 gün kalabilir ama daha sonra erkek Betayı da yavruların yanından ayırmanız gerekmektedir. Belli bir zamandan sonra erkek Beta da yavrularına saldırıp onları yiyecektir.


Yavruları ilk 1-2 hafta yumurta sarısı ile besleyebilirsiniz. Ancak çok fazla vermeyin. balıkların durumuna göre hesaplayarak verin( sayısı ve boyutunu hesaplayarak). Daha sonra akvaryumculardan rahatlıkla bulabileceğiniz toz yavru yemi ve beta yavrularının bakımı için özel yemlerden alınız. Kaliteli- sağlam bir marka olmasına dikkat ediniz. Suyun çok çabuk kirlenmemesine özen gösterin. Kesinlikle filtre kullanmayın. Eğer yavrular kış mevsiminde üredilerse ısıtıcı kullanın. Eğer yazın üredilerse( haziran-temmuz-ağustos) ısıtıcıyı sabit 18 dereceye ayarlamanız yeterli olcaktır. Yavrular doğru şekilde bakldıkları takdirde bir ay gibi kısa sürede rengarenk görünüm kazanacaklardır. Ancak ileriki zamanlarda gelişimlerinden itibaren tekrar renk değişimine uğrayacaklar ve artık gerçek renk görünümlerini kazanacaklardır. Yavru akvaryumlarında en önemli husus bol bitkili olmasına dikkat edin. Çünkü hem oksijen sağlar, hem yavruların saklanma gereksinimlerini karşılar ve hem de suyu temiz tutup çabuk kirlenmesini önler.
ALİ ÇELİK

20 Haziran 2009 Cumartesi

Joining İşlemi

Veritabanları ile ilgili olarak en gıcık işlem Joining (birleştirme) işlemidir. Mulakat ta yeni bitme bir proje yöneticisi size kaç tür Join var diye sorması muhtemeldir.
Bana sorarsınız kodlamanız iyiyse join falan hikaye Ben hep şöyle yapıyorum ; Diyelim ki bir forum uygulaması yapacaksınız (kategoriler-konular -mesajlar isimli 3 adet tablo yapmamanız imkansız herhalde)şimdi en üste kategoriler var ve bunun Primary Key ile isimlendirdiniz. KATID olsun. Şimdi Kategorilerin altında Konular var bununda yine Primary Key'i KONID olsun.Aynı zamanda hangi kategorinin konusu olduğunada karar vermek için KATID isimli bir INT tipinde sutun koyuyorum.Mesajlarda konunu alt tablosu olduğuna göre Mesajlarda da bu mantıkla yaklaşırsak yine MESID isimli primary key sonrada KATID ,KONID isimli INT tipinde sutunlar hazırlıyorsunuz.
ilişki falan kurmayı unutun ciddiyim ne yapacaz dikkat !
diyelimki kategorilerden birine tıkladınız.KATID alırsınız. Konular Tablonuza bir SELECT çekersiniz Konu.KATID=Kategori.KATID kıyaslarsınız alın size o kategorinin konuları .Aynı mantığı mesajlar içinde yapabilirsiniz. Ne ilişki ne Join Ne bilmem ne Salla gitsin. NEYSE bu söylediklerimiz yasak aman performans falan düşer facebook'unuz yada Google uygulamanız yavaş çalışır. :)

Kırmızı yazdığımız yerleri göz ardı ederek şimdi Join işlemine bakalım.
Bazen iki tablodaki bilgilere ihtiyaç duyarız.Hatta belkide daha fazlasına işte bu gibi durumlarda tablolardaki kıskaçlardan(foreig keyler ve primary keyler) tutarak birbirine bağlar. Ve select ile çekeriz.
Eğer bağlamadan iki tabloya SELECT verirsek bunların tabloların kartezyen çarpımlarını verir.
Örneğin Parça tablo 100 Müşteri tablosunda 50 kayıt olsun toplam 5000 kayıt döndürecektir.Bu örnekte ki gibi SELECT * FROM Parca,Musteri

Klasik Join İşlemi
SELECT tablo1.alan1 tablo2.alan1 FROM tablo1,tablo2 WHERE tablo1.birincianahtar= tablo2.yabancıanahtar [and diğer şartlar]

şeklinde bağlam gerçekleştirilebilir.

Self Join İşlemi (Tabloyu Kendisiyle İlişkilendirme)
Aynı tabloya iki farlı takma ad atayıp (alias) farklı tablolarmış gibi sorgulamalar yapılabilir.
Genelde pek kullanılmaz ama kontrol amaçlı işlemlerde sık sık kullanılabilir. Mesela parça listesinde aynı ürün isimleri karıştırıldığı için isimleri farklı olarak girilmiş olabilir bu nedenle barkod numarasına bakarak kontrol yapabiliriz.
SELECT T1.barkodno,T1.Urunad,T2.barkodno,T2.Urunad AS Parca T1, ParcaT2 WHERE T1.barkodno=T2.barkodno AND T1.Urunad <> T2.Urunad; gibi gibi

Left[outher] Join İşlemi
birinci tablodaki tüm veriler getirilir yanına eğer ikinci tabloda ilişkiye göre veri varsa getirilir.
SELECT Uye.Adi ,Odunc.KitapNo FROM uye LEFT JOIN odunc ON Odunc.UyeID=Uye.UyeID;
Right Join İşlemi
Right[outher] Join İşlemi
ikinci tablodaki tüm veriler getirilir yanına eğer birinci tabloda ilişkiye göre veri varsa getirilir.
SELECT Uye.Adi ,Odunc.KitapNo FROM uye RIGHT JOIN odunc ON Odunc.UyeID=Uye.UyeID;
Inner Join İşlemi
En çok kullanılan tablo birleştirme yöntemidir.her iki tablodaki ortak verileri getirir.
SELECT Uye.Adi ,Odunc.KitapNo FROM uye INNER JOIN odunc ON Odunc.UyeID=Uye.UyeID;
Klasik join işlemi aynı şeydir fakat birleştirme tekniği farklıdır. iş olsun diye yapılmış işte !.

Böylece Kafa Karıştıran join işlemlerinide hal etmiş olduk.

Tabloya Takma Ad (Alias)

Sutunlara AS ifadesi ile takma at takıldığı çok kere görmüşsünüzdür. SELECT * ToplamFiyat SUM(Fiyat) as ToplamFiyat gibi Bu yazıda ise sutuna değilde tabloya takma at takmak istiyoruz.
Özellikle içiçe sorgularda ve Join sorgularında oldukca işimize yarayacaktır.

Bunu nasıl yaparız.
SELECT k.Isim ,l.Fiyat AS Musteri k , Parca l Where l.fiyat > 1000 gibi yaparız
tablolardan sonraki boşluk konularak yapılan kısaltmalara dikkat artık tablomuzun adı kısaltma ile yapılacak

View lar

Tabloların bazı durumlarda sadece bir kısmının kullanıcıya gösterilmesi gerekmektedir.Böylesi bir durumda Select sorgusu çekerek bu azaltılmış tabloda kullanıcımıza bilgilerimizi gösterebiliriz.

İşte View ler yaşayan Select cümlecikleridir.Oluşturmak için aşağıdaki şekli kullanabilirsiniz.

CREATE VIEW view_name[(column_name[,column_name]….)]
[WITH ENCRYPTION]
AS select_statement
[WITH CHECK OPTION]

şeklinde view oluşturabilir.
Örnek
CREATE VIEW vwCustomerASSELECT CustomerId, Company Name, PhoneFROM Customers

Indexler

En baba özellikleri sorgulama sürelerini kısaltmalarıdır.index oluşturarak veritabanındaki kayıt sırasından başka bir sırada sıralama yapabiliriz.
indexler Cluster index,non-Cluster index olarak ikiye ayrılmaktadır.ve baya bir özelliği var hiç sürekli bir çalışan sql de index oluşturmak nasip olmadı ama :) eskiden index çalışan tablonun index 'i izin verilmiyormuş fakat sql server 2005 ve sonrasında izin veriliyor.çok çekirdekli bilgisayarlarda bu iş için kaç çekirdek bile ayırabileceğinizi yazıyorsunuz (maxdop mesela). index oluşturma parametreleri süper
CREATE [UNIQUE][CLUSTERED NONCLUSTERED] INDEX index_ismi
ON [{database_ismi.[schema_ismi]. schema_name.}]
{table_veya_view_ismi}(sütun [ASC DESC][,...n])
[INCLUDE (sütun_ismi[,...n])]
[WITH([,...n])]
[ON {partition_scheme_name(sütun_ismi[,...n])
filegroup_ismi DEFAULT}]

::=
{ PAD_INDEX = {ON OFF}
FILLFACTOR = fillfactor değeri
SORT_IN_TEMPDB = {ON OFF}
IGNORE_DUP_KEY = {ON OFF}
STATISTICS_NO_RECOMPUTE = {ON OFF}
DROP_EXISTING = {ON OFF}
ONLINE = {ON OFF}
ALLOW_ROW_LOCKS = {ON OFF}
ALLOW_PAGE_LOCKS = {ON OFF}
MAXDOP = processor_sayısı }

Bu kadar parametreyi anlatsakta bitmez zaten bir sorun oldukca bakarsınız adamlar bununla ilgili bir şey düşünmüşler mi diye işte !

Mevcut Tabloya Sutun ekleme düzenleme

ALTERdeyimimiz var olan tablolar üzerinde işlemler yaparken kullanılıyor.

Tabloya Alan Ekleme:

Var olan bir tabloya alan eklemek için kullanacağımız ALTER TABLE komutu aşağıdaki gibidir.

ALTER TABLE tablo_adi ADD alan_adi alan_turu;

Örneğin Uyeler tablosuna, Yer adında, 50 karakter uzunluğunda bir metin alanı ekleyelim.

ALTER TABLE Uyeler ADD Yer VARCHAR(50);

Bir komutla birden fazla alan ekleme:

Tabloya birden fazla alan eklemek için kullanacağımız kod:

ALTER TABLE tablo_adi ADD (alan1 alan_turu, alan2 alan_turu, ... alan10 alanturu);

Örnek:

ALTER TABLE Uyeler ADD (Yer VARCHAR(50), Yas INT, Uye_ID Counter, Kayit_Tarihi DATETIME, Profil MEMO);

Bu kod, Uyeler tablosuna şu alanları ekler:
Yer (Metin(50))
Yas (Sayı)
Uye_ID (Otomatik Sayı)
Kayit_Tarihi (Tarih/Saat)
Profil (Not)

Tablodaki Alanları Düzenleme

Tablodaki varolan alanları düzenlemek için kullanacağımız ALTER TABLE komutu aşağıdaki gibidir.

ALTER TABLE tablo_adi MODIFY alan_adi alan_turu;

Örneğin, Uyeler tablosunda, uzunluğu 50 karakter olan Yer alanını 100 karaktere çıkaralım.

ALTER TABLE Uyeler MODIFY Yer VARCHAR(100);

Alan Silme

Tablodaki varolan bir alanı silmek için kullanacağımız ALTER TABLE komutu aşağıdaki gibidir.

ALTER TABLE tablo_adi DROP COLUMN alan_adi;