블로그 이미지
올해목표 // 10월 어학연수 떠나자~ 자수씨

카테고리

전체글 (1457)
Brand New! (28)
주절주절 (213)
MOT (11)
해외쇼핑 (49)
쇼핑노트 (150)
취미생활 (94)
iPhone (4)
Eclipse (121)
Google (83)
Spring (31)
JAVA (176)
JavaScript (59)
WEB (49)
Database (20)
OS (26)
Tools (8)
Tips (26)
IT정보 (1)
Book (21)
Programming (37)
외부행사 (43)
주변인들 (17)
여행노트 (60)
학교생활 (30)
회사생활 (52)
사회생활 (5)
외국어공부 (12)
잡동사니 (30)
Total
Today
Yesterday
 
11-16 09:37
 

달력

« » 2024.11
1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 29 30
 

최근에 올라온 글

최근에 달린 댓글


2011/01/29 - [JAVA/Hibernate] - 하이버네이트... 해당 쿼리에 대한 전체 카운트 가지고 오기

위의 글과 같이 전체 카운트를 가지고 오는 부분을 추가했더니... 대략 18번의 쿼리가 수행된 후에 DB 수행작업이 먹통이 되어버렸습니다. 처음에는 원인을 찾지 못하다가, 세션을 가져온 후 반환을 하지 않는 것을 확인하고 코드를 수정하지 않는 선에서 해결책을 찾았습니다.




하이버네이트 프로퍼티에 hibernate.connection.release_mode 의 값을 after_transaction 로 설정하면 굳이 세션을 가져온 후 관리를 하지 않아도 되더군요... 꼭 좋은 방법은 아니지만 위와 같은 방법도 있습니다.

Posted by 자수씨
, |


전체 카운트를 어떻게 가지고 올까 고민을 하다가... 찾아보니 아래와 같이 처리를 하면 되더군요...



DetachedCriteria 를 재사용해서 쓰려다 보니 위와 같은 형식으로 작성했습니다. 헐... 근데 저렇게 사용하니 원하는 결과가 안나오더군요... 그래서 결국 DetachedCriteria 를 새로 만들어 같은 값을 설정한 후 사용하였습니다.

시간이 없어 간만에 작성하는... 포스팅...

Posted by 자수씨
, |


요즘에 한참 재미가 들린 하이버네이트와 Spring MVC, 그리고 Ext JS 를 이용하여 손쉽게 DB 테이블 데이터를 그려주는 방법을 연구하고 있었습니다.

즉, 하이버네이트로 데이터를 조회하고, Spring MVC 로 Ext JS 에서 사용할 데이터를 만들어서 Ext JS 의 컴포넌트가 요청하는 구조입니다.


만약 아래와 같은 Entity 가 있다면




VickiHibernateDaoBaseImpl 을 구현한 Dao 클래스를 생성합니다.




AbstractBaseMonitoringController 를 상속받은 Controller 클래스를 생성하였습니다.




그런 후, ConfigLoadGridPanel 의 데이터에 기본 URL 을 설정해주기만 하면!!!



아래와 같이 데이터를 확인할 수 있습니다.




역시 짜릿한 어노테이션의 손맛!!!



Posted by 자수씨
, |

iBATIS 를 이용한지는 3년정도가 지났고, Hibernate 는 올해 처음 맛을 보았습니다.

두가지 모두 각각의 장점들이 명확한지라, 어느 한쪽만 택하기가 아쉬운 점이 있습니다.

그래서 다음번 프로젝트 때는 두가지를 병행하여 사용해볼까 합니다.

CRUD 는 하이버네이트를 이용하고, 테이블 간의 조인이 필요로 할 경우에는 iBATIS 를 이용해보려 합니다.

아마도 테이블 설계가 잘 되어 있고, DB 내에 펑션이나 프로시저 처럼 로직이 들어가 있지 않다면 iBATIS 를 이용할 일이 거의 없겠지만 현실은 항상 우리편이 아니기 때문에 iBATIS 도 적절하게 사용하는 것이 생산성 향상에 도움이 될 것으로 생각합니다.

어차피 DataSource 는 공유해서 사용할 것이고... 문제가 될만한게 없겠죠???

Posted by 자수씨
, |

글 보관함

최근에 받은 트랙백