25 Ağustos 2011 Perşembe
19 Ağustos 2011 Cuma
Junit ve Mockit ile Private ve Void Methodları Test Etme
Arkadaşlar Merhabalar,
Projeleri test ederken karşılaştığımız bir problem de private ve void methodların özel durumlarıdır. Private methoda erişemediğimizden, Void methodun da birşey döndürmediğinden bu sonuç ortaya çıkar. Void method için aslında yapılabilecek çok bir şey yok, kullandığı global değişkenleri Mockit kütüphanesinin getField() fonksiyonu ile kontrol edebiliriz.
String actual = getField(instance, "exportData");
actual : Kontrol edeceğimiz parametre
instance : Parametresini çekeceğimiz obje
exportData : Parametrenin adı
Bundan sonra assertEqual fonksiyonu ile karşılaştırma yapılabilir. Private methodları çağırmak için de aşağıdaki kodu kullanabiliriz.
Class c = Class.forName("com.layers.drivers.DataDriverImpl");
Method methodParse = c.getDeclaredMethod("parseDataToExportData", new Class[]{Collection.class,Collection.class}); // Fonksiyonun adı ve aldığı parametrelerin tipi
methodParse.setAccessible(true);
Object objParse = c.newInstance();
setField(objParse, "dataExportData", mockDataExportData); // Fonksiyonun kullandığı bir global parametreyi kendi parametremizle değiştirme
methodParse.invoke(objParse, new Object[] {albumModels,genreModels}); // Fonksiyonun aldığı parametreler
Bu konuda başka bir örneğin bulunduğu linki aşağıda veriyorum. Yalnız bu linkteki örnekteki kodu kullanmak için method.setAccessible(true) kodunu eklemeniz gerekiyor, çünkü private method çalıştırmak için önce accessible yapmamız gerekiyor.
http://www.java2s.com/Tutorial/Java/0125__Reflection/Callaclassmethodwith2arguments.htm
Şimdilik bu kadar. Kafanıza takılan soruları yazarsanız beraber çözüm bulmaya çalışırız.
Herkese sevgiler, saygılar.
Projeleri test ederken karşılaştığımız bir problem de private ve void methodların özel durumlarıdır. Private methoda erişemediğimizden, Void methodun da birşey döndürmediğinden bu sonuç ortaya çıkar. Void method için aslında yapılabilecek çok bir şey yok, kullandığı global değişkenleri Mockit kütüphanesinin getField() fonksiyonu ile kontrol edebiliriz.
String actual = getField(instance, "exportData");
actual : Kontrol edeceğimiz parametre
instance : Parametresini çekeceğimiz obje
exportData : Parametrenin adı
Bundan sonra assertEqual fonksiyonu ile karşılaştırma yapılabilir. Private methodları çağırmak için de aşağıdaki kodu kullanabiliriz.
...
...Class c = Class.forName("com.layers.drivers.DataDriverImpl");
Method methodParse = c.getDeclaredMethod("parseDataToExportData", new Class[]{Collection.class,Collection.class}); // Fonksiyonun adı ve aldığı parametrelerin tipi
methodParse.setAccessible(true);
Object objParse = c.newInstance();
setField(objParse, "dataExportData", mockDataExportData); // Fonksiyonun kullandığı bir global parametreyi kendi parametremizle değiştirme
methodParse.invoke(objParse, new Object[] {albumModels,genreModels}); // Fonksiyonun aldığı parametreler
...
...
Bu konuda başka bir örneğin bulunduğu linki aşağıda veriyorum. Yalnız bu linkteki örnekteki kodu kullanmak için method.setAccessible(true) kodunu eklemeniz gerekiyor, çünkü private method çalıştırmak için önce accessible yapmamız gerekiyor.
http://www.java2s.com/Tutorial/Java/0125__Reflection/Callaclassmethodwith2arguments.htm
Şimdilik bu kadar. Kafanıza takılan soruları yazarsanız beraber çözüm bulmaya çalışırız.
Herkese sevgiler, saygılar.
Java'da Junit ile Yazılım Testi
Arkadaşlar Merhabalar,
Birkaç haftadır yazı yazamıyorum. Bunun sebebi işyerinde bana verilen işlerin yoğunlaşmış olması. Bu hafta bir test projesi verildi bana. En son adamakıllı testi ÖSSde çözmüş olan ben :), test deyince kafamda birşey oluşmadı tabii. Ama bu bir haftadaki araştırmalarım gösterdi ki, testler yazılımlar için kritik bir rol oynuyorlar ve yazılmaları bazen test edeceğimiz koddan çok daha zor olabiliyor. Mesela ben 30-40 satır bir kod için yaklaşık 150 satır test kodu yazmak durumunda kaldım. Ama gözünüzü korkutmasın, bir öğrendiniz mi gerisi geliyor :)
Test için çeşitli kütüphaneler mevcut, ben Junit'i tercih ettim. Sitesinden son versiyonunu indirip projenizin "Build path" kısmına ekleyerek kullanmaya başlayabilirsiniz. Burada yardımcı olarak bir kütüphane daha kullanacağız, bu da Jmockit kütüphanesi. Kod kısmında bazen fonksiyonları kendi istediğimiz gibi yönlendirmemiz gerekebiliyor, mesela veritabanına bağlanarak veri çeken, ama testte veritabanına bağlanmadan verileri hazırlamak istediğimiz bir metodu test ederken, projenin DAO(Data Access Object) kısmında veriyi çeken metodu Mock ederek, yani bir şekilde Bypass diyebiliriz, bu işi halledebiliriz. Nasıl olacağını kod kısmında hepberaber görelim.
// Bu method test başlamadan önce çalışır, constructor ya da page_load fonksiyonları gibi düşünebiliriz
// Burada DataDriverImpl sınıfında bulunan mockDataDriverImpl fonksiyonunu Mock ediyoruz
// Bir sınıf için birden çok fonksiyonu mock edebiliyoruz
@Mock
Kısaca test işlemi buydu. Burada zor olan kısım test işleminden ziyade Mock işlemleri bence. Daha detaylı bilgileri junitin ve jmockitin sitelerinden ve google'den öğrenebilirsiniz. Ayrıca aşağıdaki linkte de çok değerli ve geniş bilgiler bulunmaktadır.
http://erhan.kesken.org/2011/03/jmockit-ile-ideal-birim-test.html
Herkese kolay gelsin.
Birkaç haftadır yazı yazamıyorum. Bunun sebebi işyerinde bana verilen işlerin yoğunlaşmış olması. Bu hafta bir test projesi verildi bana. En son adamakıllı testi ÖSSde çözmüş olan ben :), test deyince kafamda birşey oluşmadı tabii. Ama bu bir haftadaki araştırmalarım gösterdi ki, testler yazılımlar için kritik bir rol oynuyorlar ve yazılmaları bazen test edeceğimiz koddan çok daha zor olabiliyor. Mesela ben 30-40 satır bir kod için yaklaşık 150 satır test kodu yazmak durumunda kaldım. Ama gözünüzü korkutmasın, bir öğrendiniz mi gerisi geliyor :)
Test için çeşitli kütüphaneler mevcut, ben Junit'i tercih ettim. Sitesinden son versiyonunu indirip projenizin "Build path" kısmına ekleyerek kullanmaya başlayabilirsiniz. Burada yardımcı olarak bir kütüphane daha kullanacağız, bu da Jmockit kütüphanesi. Kod kısmında bazen fonksiyonları kendi istediğimiz gibi yönlendirmemiz gerekebiliyor, mesela veritabanına bağlanarak veri çeken, ama testte veritabanına bağlanmadan verileri hazırlamak istediğimiz bir metodu test ederken, projenin DAO(Data Access Object) kısmında veriyi çeken metodu Mock ederek, yani bir şekilde Bypass diyebiliriz, bu işi halledebiliriz. Nasıl olacağını kod kısmında hepberaber görelim.
// Bu method test başlamadan önce çalışır, constructor ya da page_load fonksiyonları gibi düşünebiliriz
@Before
public void setUp() throws Exception {
instance = new HafifmuzikDriverImpl();
}
// Bu method da test bittikten sonra çalışır, veritabanı bağlantısını vb. kesebileceğiniz yerdir. Hata yakalamadaki finally kısmına benzer. @After
public void tearDown() throws Exception {
}
// Burada DataDriverImpl sınıfında bulunan mockDataDriverImpl fonksiyonunu Mock ediyoruz
MockUp<DataDriverImpl> mockDataDriverImpl = new MockUp<DataDriverImpl>(){
@Mock
public String fillExportDataWith(){ return mockDataExportData;
}// Bir sınıf için birden çok fonksiyonu mock edebiliyoruz
@Mock
public DataLogger getLogger() {
return DataLoggerFactory.getLoggerInstance(this.getClass());
}
};
...
...
...
// Burada karşılaştırma işlemi yapılıyor, ilk parametre expected value, ikincisi actual value. assertEquals("12486564", fillExportDataWith());
Kısaca test işlemi buydu. Burada zor olan kısım test işleminden ziyade Mock işlemleri bence. Daha detaylı bilgileri junitin ve jmockitin sitelerinden ve google'den öğrenebilirsiniz. Ayrıca aşağıdaki linkte de çok değerli ve geniş bilgiler bulunmaktadır.
http://erhan.kesken.org/2011/03/jmockit-ile-ideal-birim-test.html
Herkese kolay gelsin.
9 Ağustos 2011 Salı
Hibernate - Annotation ile One-to-Many Mapping - 2
Herkese Merhabalar,
Kısa bir konudan bahsedeceğim yine. Hibernatede One-to-One ilişkide iki tablo arasında kurulan bağlantının ayrı bir Join tablosunda tutulmasını gerçekleştiren annotationlarımız kısaca aşağıdaki gibidir. Belki birileriinni işine yarar :)
Driver.Java
@Entity
@Table(name="DRIVER")
public class Driver {
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
@Column(name="ID")
private int driverId;
@OneToOne(cascade=CascadeType.ALL)
@JoinTable(name="Driver_Vehicle",joinColumns={@JoinColumn(name="ID")},inverseJoinColumns={@JoinColumn(name="VID")})
private Vehicle vehicle;
...
...
}
Vehicle.Java
One-to-Many için de benzer kodlar geçerlidir. List ve ArrayList kullanımında bir değişikliğe gerek yok iken, HashMap kullanımında @MapKeyColumn annotationu kullanımı işe yarayacaktır.
Herkese kolay gelsin.
Kısa bir konudan bahsedeceğim yine. Hibernatede One-to-One ilişkide iki tablo arasında kurulan bağlantının ayrı bir Join tablosunda tutulmasını gerçekleştiren annotationlarımız kısaca aşağıdaki gibidir. Belki birileriinni işine yarar :)
Driver.Java
@Entity
@Table(name="DRIVER")
public class Driver {
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
@Column(name="ID")
private int driverId;
@OneToOne(cascade=CascadeType.ALL)
@JoinTable(name="Driver_Vehicle",joinColumns={@JoinColumn(name="ID")},inverseJoinColumns={@JoinColumn(name="VID")})
private Vehicle vehicle;
...
...
}
Vehicle.Java
@Entity
@Inheritance(strategy=InheritanceType.TABLE_PER_CLASS)
public abstract class Vehicle {
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
@Column(name="VID")
private int id;
@Inheritance(strategy=InheritanceType.TABLE_PER_CLASS)
public abstract class Vehicle {
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
@Column(name="VID")
private int id;
...
...
}One-to-Many için de benzer kodlar geçerlidir. List ve ArrayList kullanımında bir değişikliğe gerek yok iken, HashMap kullanımında @MapKeyColumn annotationu kullanımı işe yarayacaktır.
Herkese kolay gelsin.
8 Ağustos 2011 Pazartesi
Hibernate ile Abstract Sınıfı Veritabanına Kaydetme - 2
Herkese Merhabalar,
Bugün yine Hibernate frameworku ile devam ediyoruz. Bu seferki problem oldukça karışık, benim için anlatması sizin için anlaması zor olacak sanırım ama deneyeceğiz bakalım :)
Elimizde bir adet abstract sınıf var, 2 tane de bundan türeyen POJO sınıf, bir tane de bu abstract sınıfla has-a-relation bağlantısı olan Java sınıfı. Şöyle düşünebilirsiniz, son bahsettiğim java sınıfı bir sürücü. Bir sürücü çeşitli araçlar sürebilir, traktör, kamyon vs. İşte bu sürdüğü arabayı temsilen içinde bir abstract sınıf var, taşıt oluyor bu da. 2 adet POJO sınıfımız da taşıt türleri oluyor, otobüs ve kamyon atıyorum. Bunlar abstract sınıfı extend ediyor daha önce dediğim gibi. Böylelikle bütün sürücüler için sürdüğü aracın türünü belirtmeden esnek bir şekilde tutabiliyoruz. Bun OOP olarak gerçekleştirmekte bir sorun yok ama, Hibernate ile veritabanına kaydedecekken biraz sorun çıkabiliyor. Bu da aslında daha önceki yazımda bahsettiğim @MappedSuperClass annotationu ile denemem sonucu oluştu sanırım. @MappedSuperClass annotationu verdiğimiz bir sınıfı başka bir sınıf içerisinde has-a-relation ilişkisiyle bulundurduğumuz zaman bir sorun çıkıyor. Burada bu annotationu @Entity ile değiştirmemiz gerekiyor. Aşağıda basitçe yazacağım kullanmamız gereken annotationları, umarım faydalı olur.
Bus.Java
Truck.Java
@Entity
@Table(name="TRUCK")
public class Truck extends Vehicle{
...
}
Driver.Java
@Entity
@Table(name="DRIVER")
public class Driver {
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
@Column(name="ID")
private int driverId;
@OneToOne(cascade=CascadeType.ALL)
@JoinColumn(name="Vehicle_Id")
private Vehicle vehicle;
...
}
Vehicle.Java
Kafanıza takılan sorular olursa çekinmeden sorabilirsiniz. Herkese kolay gelsin.
Bugün yine Hibernate frameworku ile devam ediyoruz. Bu seferki problem oldukça karışık, benim için anlatması sizin için anlaması zor olacak sanırım ama deneyeceğiz bakalım :)
Elimizde bir adet abstract sınıf var, 2 tane de bundan türeyen POJO sınıf, bir tane de bu abstract sınıfla has-a-relation bağlantısı olan Java sınıfı. Şöyle düşünebilirsiniz, son bahsettiğim java sınıfı bir sürücü. Bir sürücü çeşitli araçlar sürebilir, traktör, kamyon vs. İşte bu sürdüğü arabayı temsilen içinde bir abstract sınıf var, taşıt oluyor bu da. 2 adet POJO sınıfımız da taşıt türleri oluyor, otobüs ve kamyon atıyorum. Bunlar abstract sınıfı extend ediyor daha önce dediğim gibi. Böylelikle bütün sürücüler için sürdüğü aracın türünü belirtmeden esnek bir şekilde tutabiliyoruz. Bun OOP olarak gerçekleştirmekte bir sorun yok ama, Hibernate ile veritabanına kaydedecekken biraz sorun çıkabiliyor. Bu da aslında daha önceki yazımda bahsettiğim @MappedSuperClass annotationu ile denemem sonucu oluştu sanırım. @MappedSuperClass annotationu verdiğimiz bir sınıfı başka bir sınıf içerisinde has-a-relation ilişkisiyle bulundurduğumuz zaman bir sorun çıkıyor. Burada bu annotationu @Entity ile değiştirmemiz gerekiyor. Aşağıda basitçe yazacağım kullanmamız gereken annotationları, umarım faydalı olur.
Bus.Java
@Entity
@Table(name="BUS")
public class Bus extends Vehicle{
@Table(name="BUS")
public class Bus extends Vehicle{
...
}Truck.Java
@Entity
@Table(name="TRUCK")
public class Truck extends Vehicle{
...
}
Driver.Java
@Entity
@Table(name="DRIVER")
public class Driver {
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
@Column(name="ID")
private int driverId;
@OneToOne(cascade=CascadeType.ALL)
@JoinColumn(name="Vehicle_Id")
private Vehicle vehicle;
...
}
Vehicle.Java
@Entity
@Inheritance(strategy=InheritanceType.TABLE_PER_CLASS)
public abstract class Vehicle {
@Inheritance(strategy=InheritanceType.TABLE_PER_CLASS)
public abstract class Vehicle {
...
}Kafanıza takılan sorular olursa çekinmeden sorabilirsiniz. Herkese kolay gelsin.
5 Ağustos 2011 Cuma
Hibernate ile Abstract Sınıfı Veritabanına Kaydetme
Arkadaşlar Merhabalar,
Bugün size çok kısa ve yararlı bir bilgi vereceğim. Hibernate ile uğraşırken karşıma şu sorun çıktı, elimde 3 tane sınıf ve 1 tane abstract sınıf var. 3 sınıf da bu abstract sınıfı extend ediyor ve veritabanına kaydederken, bu sınıfların türüne göre kaydetmesini istiyorum. Örneğin,
AbstractClass a = new Class1();
session.save(a);
ise veritabanında Class1'in tablosuna kaydetmesini, Class2 ise başka bir tabloya kaydetmesini istiyorum. Bunun için, abstract sınıfın başındaki @Entity annotationunu silip aşağıdaki annotationu yazarız.
@MappedSuperclass
Böylelikle amacımıza ulaşmış olacağız. Umarım faydalı olur. Herkese kolay gelsin.
Bugün size çok kısa ve yararlı bir bilgi vereceğim. Hibernate ile uğraşırken karşıma şu sorun çıktı, elimde 3 tane sınıf ve 1 tane abstract sınıf var. 3 sınıf da bu abstract sınıfı extend ediyor ve veritabanına kaydederken, bu sınıfların türüne göre kaydetmesini istiyorum. Örneğin,
AbstractClass a = new Class1();
session.save(a);
ise veritabanında Class1'in tablosuna kaydetmesini, Class2 ise başka bir tabloya kaydetmesini istiyorum. Bunun için, abstract sınıfın başındaki @Entity annotationunu silip aşağıdaki annotationu yazarız.
@MappedSuperclass
Böylelikle amacımıza ulaşmış olacağız. Umarım faydalı olur. Herkese kolay gelsin.
4 Ağustos 2011 Perşembe
Hibernate için İnternetteki Faydalı Linkler
Merhabalar,
Sizlerle internette bulduğum Hibernate ile alakalı faydalı linkleri paylaşmak istiyorum. Hem sizler faydalanmış olursunuz, hem de ben unutmamış olurum :)
- http://www.vaannila.com/index.html (Hibernate dahil birçok öğrenilmesi gereken konuları çok güzel bir şekilde anlatmış)
- http://www.roseindia.net/hibernate/
- Ve tabii ki.. http://www.hibernate.org (Siteen indirebileceğiniz user manual'i dikkatle okumanızı tavsiye ederim, böylelikle ezbere gitmektense öğrenerek ilerlemiş olursunuz)
- http://www.hiberbook.com/
Aklıma geldikçe bu listeyi kabartacağım :) Herkese kolay gelsin.
Sizlerle internette bulduğum Hibernate ile alakalı faydalı linkleri paylaşmak istiyorum. Hem sizler faydalanmış olursunuz, hem de ben unutmamış olurum :)
- http://www.vaannila.com/index.html (Hibernate dahil birçok öğrenilmesi gereken konuları çok güzel bir şekilde anlatmış)
- http://www.roseindia.net/hibernate/
- Ve tabii ki.. http://www.hibernate.org (Siteen indirebileceğiniz user manual'i dikkatle okumanızı tavsiye ederim, böylelikle ezbere gitmektense öğrenerek ilerlemiş olursunuz)
- http://www.hiberbook.com/
Aklıma geldikçe bu listeyi kabartacağım :) Herkese kolay gelsin.
Hibernate - Annotation ile One-to-Many Mapping
Merhabalar,
Bugün Hibernate Framework'u ile one-to-many ilişkisi olan sınıfları veritabanımıza nasıl kaydeder ve çekeriz inceleyeceğiz.
Öncelikle, one-to-many nedir bunu inceleyelim. OOP terimlerinden olup, birden çoğa ilişki olarak Türkçeleştirilebilir. Bir örnekle açıklamak gerekirse, bir okulumuz var ve içinde öğrenciler var. Her öğrenciye ait bir veya daha fazla telefon numarası var. Bunu aşağıdaki şekilde gösterebiliriz.

Bu gibi bir durumu gerçeklemek için yazacağımız annotationları aşağıya kısaca yazıyorum, kodları koymak hayli uzun süreceği için.
List ve ArrayList objeleri için de yapmak için @MapKeyColumn kısmını çıkartmak yeterli olacaktır. şimdilik bu kadar.
Kolay gelsin.
Bugün Hibernate Framework'u ile one-to-many ilişkisi olan sınıfları veritabanımıza nasıl kaydeder ve çekeriz inceleyeceğiz.
Öncelikle, one-to-many nedir bunu inceleyelim. OOP terimlerinden olup, birden çoğa ilişki olarak Türkçeleştirilebilir. Bir örnekle açıklamak gerekirse, bir okulumuz var ve içinde öğrenciler var. Her öğrenciye ait bir veya daha fazla telefon numarası var. Bunu aşağıdaki şekilde gösterebiliriz.
Bu gibi bir durumu gerçeklemek için yazacağımız annotationları aşağıya kısaca yazıyorum, kodları koymak hayli uzun süreceği için.
@OneToMany(fetch = FetchType.EAGER, cascade = { CascadeType.ALL })
@JoinTable(name="CAR_CITY",joinColumns={@JoinColumn(name="ID")},inverseJoinColumns={@JoinColumn(name="CITY_ID")})
@MapKeyColumn(name="carkey")
@JoinTable(name="CAR_CITY",joinColumns={@JoinColumn(name="ID")},inverseJoinColumns={@JoinColumn(name="CITY_ID")})
@MapKeyColumn(name="carkey")
private Map<String, City> cityMap = new HashMap<String, City>();
Kolay gelsin.
3 Ağustos 2011 Çarşamba
Hibernate ile Java Projesi Geliştirme ve Inner Join Sorgusunu Gerçekleme
Herkese merhabalar,
Castor üzerinde uzunca bir süre çalıştıktan sonra, artık sıra popüler framework Hibernate'yi öğrenmeye gelmişti. Bu hafta başında çalışmaya başladığım Hibernate'de güzel tecrübeler elde ettim. Aşağıda Hibernate ile geliştirilmiş bir Java projesi var, bunu inceleyelim. Burada ilk gerçeklediğim örneklerden ziyade, son olarak yaptığım projeyi koymayı uygun gördüm, basitten değil de zordan başlamayı denemek lazım bir sefer de :)
Hibernate iyidir hoştur, basit select, insert, update ve delete querylerimizi çalıştırır sağolsun da, işim içine obje ilişkileri girdi mi biraz durum farklılaşıyor. Mesela iki adet tablonuz var ve bunlar arasında bir ilişki kurarak bir sorgu hazırlayacaksınız(mesela select * from t1 inner join t2 ... gibi). Bunu gerçeklerken öncekilerden farklı olarak SQL querysini olduğu gibi Java kodları arasına yazmamız gerekiyor, diğer türlü bu işlem gerçekleşmiyor. Query sınıfıyla yapınca inner join ... on ... kalıbını tanımıyor, bilmiyorum bu konuyu çözmek adına birşey yaptılar mı, dolayısıyla bu sorunu SQLQuery sınıfıyla çözüyoruz. Aşağıda daha net biçimde görülebilir.
Bu projede kullanılan kütüphaneleri de yazmakta fayda var, zira bazen eski ve yeni versiyon kütüphaneler bir arada çalışırken sıkıntı olabiliyor, doğru kütüphaneleri kullanmak burada önem kazanıyor.
- antlr-2.7.6.jar
- commons-collections-3.1.jar
- dom4j-1.6.1.jar
- hibernate-jpa-2.0-api-1.0.0.Final.jar
- hibernate3.jar
- javassist-3.9.0.GA.jar
- jta-1.1.jar
- ojdbc14.jar(Kullandığım veritabanı Oracle olduğu için bunu kullanıyorum, diğer veritabanları için farklı kütüphaneleri Google'dan bulabilirsiniz.)
- slf4j-api-1.5.8.jar
- slf4j-simple-1.5.8.jar
Şimdi gelelim kodlara.
Car.Java
package com.emre.model;
import java.util.Date;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
/**
* @author gozenem
*
*/
@Entity
@Table(name="CAR")
public class Car {
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
@Column(name="ID")
private int id;
@Column(name="BRAND", nullable=false)
private String brand;
@Column(name="MODEL")
private String model;
@Column(name="PRODUCTIONDATE")
private Date productionDate;
@Column(name="AMOUNT")
private int amount;
public Car(String brand, String model, Date productionDate, int amount) {
super();
this.brand = brand;
this.model = model;
this.productionDate = productionDate;
this.amount = amount;
}
public Car() {
super();
// TODO Auto-generated constructor stub
}
public String getBrand() {
return brand;
}
public void setBrand(String brand) {
this.brand = brand;
}
public String getModel() {
return model;
}
public void setModel(String model) {
this.model = model;
}
public Date getProductionDate() {
return productionDate;
}
public void setProductionDate(Date productionDate) {
this.productionDate = productionDate;
}
public int getAmount() {
return amount;
}
public void setAmount(int amount) {
this.amount = amount;
}
public void setId(int id) {
this.id = id;
}
public int getId() {
return id;
}
public void updateCar(Car car){
this.amount = car.amount;
this.brand = car.brand;
this.model = car.model;
this.productionDate = car.productionDate;
}
}
City.Java
package com.emre.model;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.Table;
@Entity
@Table(name="CITY")
public class City { private long id;
private String name;
public City(String name) {
super();
this.name = name;
}
public City() {}
@Id
@GeneratedValue
@Column(name="CITY_ID")
public long getId() {
return id;
}
public void setId(long id) {
this.id = id;
}
@Column(name="CITY_NAME", nullable=false)
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
CarDAO.Java
package com.emre.dao;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import org.hibernate.HibernateException;
import org.hibernate.PropertyValueException;
import org.hibernate.SQLQuery;
import org.hibernate.Session;
import com.emre.model.Car;
import com.emre.model.City;
import com.emre.util.HibernateUtil;
public class CarDAO {
private Session session;
public void addCar(Car car){
try {
session = HibernateUtil.getSessionFactory().openSession();
session.getTransaction().begin();
session.save(car);
session.getTransaction().commit();
}
catch(PropertyValueException ex){
System.out.println("Marka boş olamaz !");
}
catch(HibernateException ex){
session.getTransaction().rollback();
ex.printStackTrace();
}
finally{
session.close();
}
}
public void deleteCar(int id){
try {
session = HibernateUtil.getSessionFactory().openSession();
session.getTransaction().begin();
Car car = (Car) session.get(Car.class, id);
session.delete(car);
session.getTransaction().commit();
session.flush();
session.close();
} catch (HibernateException e) {
// TODO Auto-generated catch block
session.getTransaction().rollback();
e.printStackTrace();
}
}
public void updateCar(int id, Car newCar){
try {
session = HibernateUtil.getSessionFactory().openSession();
session.getTransaction().begin();
Car car = (Car) session.get(Car.class, id);
car.updateCar(newCar);
session.getTransaction().commit();
session.flush();
session.close();
}
catch(PropertyValueException ex){
System.out.println("Marka boş olamaz !");
}
catch (HibernateException e) {
// TODO Auto-generated catch block
session.getTransaction().rollback();
e.printStackTrace();
}
}
@SuppressWarnings("finally")
public Car searchCar(int id){
Car car = null;
try {
session = HibernateUtil.getSessionFactory().openSession();
session.getTransaction().begin();
car = (Car) session.get(Car.class, id);
session.getTransaction().commit();
session.flush();
session.close();
} catch (HibernateException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
finally{
return car;
}
}
@SuppressWarnings({ "unchecked", "finally" })
public ArrayList<Object[]> searchCarList(){
ArrayList<Object[]> cars = null;
try {
session = HibernateUtil.getSessionFactory().openSession();
session.getTransaction().begin();
SQLQuery query = session.createSQLQuery("Select * from Car c inner join City ci on c.Id = ci.City_Id");
query.addEntity(Car.class);
query.addEntity(City.class);
cars = (ArrayList<Object[]>) query.list();
session.getTransaction().commit();
} catch (HibernateException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
finally{
session.close();
return cars;
}
}
}
HibernateUtil.Java
package com.emre.util;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.AnnotationConfiguration;
import com.emre.model.Car;
import com.emre.model.City;
public class HibernateUtil {
private static final SessionFactory sessionFactory;
static {
try {
sessionFactory = new AnnotationConfiguration()
.configure()
.addPackage("com.emre.model")
.addAnnotatedClass(Car.class)
.addAnnotatedClass(City.class)
.buildSessionFactory();
} catch (Throwable ex) {
throw new ExceptionInInitializerError(ex);
}
}
public static SessionFactory getSessionFactory() {
return sessionFactory;
}
}
hibernate.cfg.xml
<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<property name="hibernate.connection.driver_class">oracle.jdbc.driver.OracleDriver</property>
<property name="hibernate.connection.url">URLniz</property>
<property name="hibernate.connection.username">Kullanıcı Adınız</property>
<property name="hibernate.connection.password">Şifreniz</property>
<property name="hibernate.connection.pool_size">10</property>
<property name="show_sql">true</property>
<property name="dialect">org.hibernate.dialect.OracleDialect</property>
<property name="hibernate.hbm2ddl.auto">update</property> <!-- Otomatik tablo olusturma -->
<!-- Mapping files -->
<!-- <mapping class="Student" /> -->
</session-factory>
</hibernate-configuration>
Main.Java
package com.emre.main;
import java.util.ArrayList;
import java.util.Date;
import java.util.List
import com.emre.dao.CarDAO;
import com.emre.model.Car;
import com.emre.model.City;
public class Main {
public static void main(String[] args) {
CarDAO cDao = new CarDAO();
ArrayList<Object[]> cars = cDao.searchCarList();
}
}
Annotations ile ilgili güzel bir link aşağıda.
http://www.jumpingbean.co.za/blogs/mark/hibernate_hql_inner_join_on_clause
Ayrıca, yukarıdaki projeyi geliştiriken faydalandığım linki de vermeden geçmek olmaz.
http://loianegroner.com/2010/06/hibernate-3-annotations-tutorial/
Kafanıza takılan birşeyler olursa sorabilirsiniz. Herkese kolay gelsin.
Castor üzerinde uzunca bir süre çalıştıktan sonra, artık sıra popüler framework Hibernate'yi öğrenmeye gelmişti. Bu hafta başında çalışmaya başladığım Hibernate'de güzel tecrübeler elde ettim. Aşağıda Hibernate ile geliştirilmiş bir Java projesi var, bunu inceleyelim. Burada ilk gerçeklediğim örneklerden ziyade, son olarak yaptığım projeyi koymayı uygun gördüm, basitten değil de zordan başlamayı denemek lazım bir sefer de :)
Hibernate iyidir hoştur, basit select, insert, update ve delete querylerimizi çalıştırır sağolsun da, işim içine obje ilişkileri girdi mi biraz durum farklılaşıyor. Mesela iki adet tablonuz var ve bunlar arasında bir ilişki kurarak bir sorgu hazırlayacaksınız(mesela select * from t1 inner join t2 ... gibi). Bunu gerçeklerken öncekilerden farklı olarak SQL querysini olduğu gibi Java kodları arasına yazmamız gerekiyor, diğer türlü bu işlem gerçekleşmiyor. Query sınıfıyla yapınca inner join ... on ... kalıbını tanımıyor, bilmiyorum bu konuyu çözmek adına birşey yaptılar mı, dolayısıyla bu sorunu SQLQuery sınıfıyla çözüyoruz. Aşağıda daha net biçimde görülebilir.
Bu projede kullanılan kütüphaneleri de yazmakta fayda var, zira bazen eski ve yeni versiyon kütüphaneler bir arada çalışırken sıkıntı olabiliyor, doğru kütüphaneleri kullanmak burada önem kazanıyor.
- antlr-2.7.6.jar
- commons-collections-3.1.jar
- dom4j-1.6.1.jar
- hibernate-jpa-2.0-api-1.0.0.Final.jar
- hibernate3.jar
- javassist-3.9.0.GA.jar
- jta-1.1.jar
- ojdbc14.jar(Kullandığım veritabanı Oracle olduğu için bunu kullanıyorum, diğer veritabanları için farklı kütüphaneleri Google'dan bulabilirsiniz.)
- slf4j-api-1.5.8.jar
- slf4j-simple-1.5.8.jar
Şimdi gelelim kodlara.
Car.Java
package com.emre.model;
import java.util.Date;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
/**
* @author gozenem
*
*/
@Entity
@Table(name="CAR")
public class Car {
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
@Column(name="ID")
private int id;
@Column(name="BRAND", nullable=false)
private String brand;
@Column(name="MODEL")
private String model;
@Column(name="PRODUCTIONDATE")
private Date productionDate;
@Column(name="AMOUNT")
private int amount;
public Car(String brand, String model, Date productionDate, int amount) {
super();
this.brand = brand;
this.model = model;
this.productionDate = productionDate;
this.amount = amount;
}
public Car() {
super();
// TODO Auto-generated constructor stub
}
public String getBrand() {
return brand;
}
public void setBrand(String brand) {
this.brand = brand;
}
public String getModel() {
return model;
}
public void setModel(String model) {
this.model = model;
}
public Date getProductionDate() {
return productionDate;
}
public void setProductionDate(Date productionDate) {
this.productionDate = productionDate;
}
public int getAmount() {
return amount;
}
public void setAmount(int amount) {
this.amount = amount;
}
public void setId(int id) {
this.id = id;
}
public int getId() {
return id;
}
public void updateCar(Car car){
this.amount = car.amount;
this.brand = car.brand;
this.model = car.model;
this.productionDate = car.productionDate;
}
}
City.Java
package com.emre.model;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.Table;
@Entity
@Table(name="CITY")
public class City { private long id;
private String name;
public City(String name) {
super();
this.name = name;
}
public City() {}
@Id
@GeneratedValue
@Column(name="CITY_ID")
public long getId() {
return id;
}
public void setId(long id) {
this.id = id;
}
@Column(name="CITY_NAME", nullable=false)
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
CarDAO.Java
package com.emre.dao;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import org.hibernate.HibernateException;
import org.hibernate.PropertyValueException;
import org.hibernate.SQLQuery;
import org.hibernate.Session;
import com.emre.model.Car;
import com.emre.model.City;
import com.emre.util.HibernateUtil;
public class CarDAO {
private Session session;
public void addCar(Car car){
try {
session = HibernateUtil.getSessionFactory().openSession();
session.getTransaction().begin();
session.save(car);
session.getTransaction().commit();
}
catch(PropertyValueException ex){
System.out.println("Marka boş olamaz !");
}
catch(HibernateException ex){
session.getTransaction().rollback();
ex.printStackTrace();
}
finally{
session.close();
}
}
public void deleteCar(int id){
try {
session = HibernateUtil.getSessionFactory().openSession();
session.getTransaction().begin();
Car car = (Car) session.get(Car.class, id);
session.delete(car);
session.getTransaction().commit();
session.flush();
session.close();
} catch (HibernateException e) {
// TODO Auto-generated catch block
session.getTransaction().rollback();
e.printStackTrace();
}
}
public void updateCar(int id, Car newCar){
try {
session = HibernateUtil.getSessionFactory().openSession();
session.getTransaction().begin();
Car car = (Car) session.get(Car.class, id);
car.updateCar(newCar);
session.getTransaction().commit();
session.flush();
session.close();
}
catch(PropertyValueException ex){
System.out.println("Marka boş olamaz !");
}
catch (HibernateException e) {
// TODO Auto-generated catch block
session.getTransaction().rollback();
e.printStackTrace();
}
}
@SuppressWarnings("finally")
public Car searchCar(int id){
Car car = null;
try {
session = HibernateUtil.getSessionFactory().openSession();
session.getTransaction().begin();
car = (Car) session.get(Car.class, id);
session.getTransaction().commit();
session.flush();
session.close();
} catch (HibernateException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
finally{
return car;
}
}
@SuppressWarnings({ "unchecked", "finally" })
public ArrayList<Object[]> searchCarList(){
ArrayList<Object[]> cars = null;
try {
session = HibernateUtil.getSessionFactory().openSession();
session.getTransaction().begin();
SQLQuery query = session.createSQLQuery("Select * from Car c inner join City ci on c.Id = ci.City_Id");
query.addEntity(Car.class);
query.addEntity(City.class);
cars = (ArrayList<Object[]>) query.list();
session.getTransaction().commit();
} catch (HibernateException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
finally{
session.close();
return cars;
}
}
}
HibernateUtil.Java
package com.emre.util;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.AnnotationConfiguration;
import com.emre.model.Car;
import com.emre.model.City;
public class HibernateUtil {
private static final SessionFactory sessionFactory;
static {
try {
sessionFactory = new AnnotationConfiguration()
.configure()
.addPackage("com.emre.model")
.addAnnotatedClass(Car.class)
.addAnnotatedClass(City.class)
.buildSessionFactory();
} catch (Throwable ex) {
throw new ExceptionInInitializerError(ex);
}
}
public static SessionFactory getSessionFactory() {
return sessionFactory;
}
}
hibernate.cfg.xml
<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<property name="hibernate.connection.driver_class">oracle.jdbc.driver.OracleDriver</property>
<property name="hibernate.connection.url">URLniz</property>
<property name="hibernate.connection.username">Kullanıcı Adınız</property>
<property name="hibernate.connection.password">Şifreniz</property>
<property name="hibernate.connection.pool_size">10</property>
<property name="show_sql">true</property>
<property name="dialect">org.hibernate.dialect.OracleDialect</property>
<property name="hibernate.hbm2ddl.auto">update</property> <!-- Otomatik tablo olusturma -->
<!-- Mapping files -->
<!-- <mapping class="Student" /> -->
</session-factory>
</hibernate-configuration>
Main.Java
package com.emre.main;
import java.util.ArrayList;
import java.util.Date;
import java.util.List
import com.emre.dao.CarDAO;
import com.emre.model.Car;
import com.emre.model.City;
public class Main {
public static void main(String[] args) {
CarDAO cDao = new CarDAO();
ArrayList<Object[]> cars = cDao.searchCarList();
}
}
Annotations ile ilgili güzel bir link aşağıda.
http://www.jumpingbean.co.za/blogs/mark/hibernate_hql_inner_join_on_clause
Ayrıca, yukarıdaki projeyi geliştiriken faydalandığım linki de vermeden geçmek olmaz.
http://loianegroner.com/2010/06/hibernate-3-annotations-tutorial/
Kafanıza takılan birşeyler olursa sorabilirsiniz. Herkese kolay gelsin.
Kaydol:
Kayıtlar (Atom)