Apache Derby'de Tablo ve Veritabanı Oluşturma

Bu derste Derby Gömülü Veritabanı ile tablo ve veritabanı oluşturmayı öğrenelim..

Merhaba arkadaşlar, Bu dersimizde Derby Gömülü Veritabanında veri tabanı ve tablo oluşturmaktan bahsedeceğim. Derby Gömülü Veri tabanı sunucu özelliği taşımaz ve tek kullanıcılıdır. Yani Derby ile oluşturulmuş bir veri tabanını sadece bir program kullanır. Derby de ufak değişiklikler olsa da genel itibariyla tablo oluşturma diğer VTYS'lerle aynıdır ve aynı mantıkta çalışır. Şimdi kısaca basit bir veri tabanı ve tablo oluşturmaktan bahsedeceğim. Veri Tabanımızın adı : EclipseTurkiye olusun. Tablomuzun ismi ise sanalKursKategori olsun ve sanalKursKategori tablosun da id, katAdi sütunları olsun. Derby'de veri tabanı oluşturma kodu aşağıdaki gibidir:


"jdbcerby:c:/EclipseTurkiye;create=true";

Bunun anlamı şudur: jdbc derby ile c: sürücüsünde EclipseTurkiye adında bir veri tabanı yoksa oluştur. Create=true "yoksa oluştur" anlamında kullanılmıştır. Burada veri tabanı oluştururken c:/EclipseTurkiye adında c: / sürücüsüne yeni bir veri tabanı klasorü oluşturmaktadır, bu işi otomatik olarak da yaptırabiliriz bu için Java'da "separatorChar" adında bir sınıf kullanılır. Kullanımı aşağıdaki gibidir Windows'ta ve Linux'ta direkt kullanıcı dosyalarına(XP'de belgelerim) veri tabanı klasörünü oluşturur;

static { String ev, sistem; ev = System.getProperty("user.home", "."); sistem = ev + File.separatorChar + ".EclipseTurkiye"; System.setProperty("derby.system.home", sistem); try { Class.forName("org.apache.derby.jdbc.EmbeddedDriver"); } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } }

User.home kullanıcı dizini demektir, yani hangi işletim sistemi kullanıyorsanız oranın kullanıcı dosyalarının içine otomatik olarak .EclipseTurkiye adında bir klasör oluşturuyor. Bunu oluşturmadan önce aşağıdaki adımları izler ve bazı tespitler yapar.

ev = System.getProperty("user.home", ".");


System.setProperty("derby.system.home", sistem); //burada kullanıcının işletim sistemi tespit ediliyor.

Yani; Sistem ve ev değişkeninden klasör oluşturacağı kullanıcı (User) dizinini buluyor ve EclipseTurkiye adında bir klasör oluşturuyor tıpkı aşağıdaki gibi.

sistem = ev + File.separatorChar + ".EclipseTurkiye";

sistem = ev birbiri ile ilişkilendirilip File.separatorChar ile "EclipseTurkiye" klasörü oluşturuluyor. Kısaca otomatik veri tabanı yolu oluşturma böyle gerçekleşiyor. Gelelim Tablo oluşturmaya: Derby de diğer SQL kullanan VTYS'lere göre ufak değişiklikler var şimdi aşağıda göreceksiniz bu değişiklikleri.

CREATE TABLE sanalKursKategori (id INTEGER NOT NULL GENERATED ALWAYS AS IDENTITY (START WITH 1, INCREMENT BY 1), katAdi VARCHAR(50))


CREATE TABLE sanalKursKategori

Burada demek istenen şudur; SanalKursKategori adında bir tablo oluştur.

id INTEGER NOT NULL GENERATED ALWAYS AS IDENTITY (START WITH 1, INCREMENT BY 1)

Burada ise id adında tam sayı olarak üretilen kimlik birincil anahtardır ve her zaman bir den başlar ve birer birer artar anlamına gelmektedir.

katAdi VARCHAR(50)

ise katAdi adında ki sutun kısıtlı metindir ve 50 karakterden fazla kullanıcı giriş yapamaz. Karakterden fazla derken sadece karakter türünde ki sayı harf ve özel karakter anlamına gelmektedir. Integer türünde ki bir java karakterini buraya kayıt yaptıramazsınız. Anlaşılan o ki Derby'de diğer SQL kullanan VTYS'ler gibi aynı özellikleri taşımaktadır fakat yazım farklılıkları göstermektedir. Bugünki dersimiz bu kadar. Umarım sizlerin işine yarayacak konulara değinmişimdir. İyi dersler diliyorum.
Emrah Dedeoğlu
2012'de Bilgisayar Teknolojileri bölümünden mezun oldu. Java Swing ile çeşitli programlar geliştirdi. Raporlama (IREPORTS) tasarımı ve Derby gömülü veritabanı(SQL) hakkında programlama bilgisine sahiptir.
Yorum Yaz

Yorum yazabilmek için üye girişi yapmanız gerekiyor!

Yukarı Git