ResultSet 은 Serializable 을 지원하지 않는다. 따라서, 파일로 쓰려면
Serializable 이 지원되는 RowSet 으로 변환해서 사용해야한다.
jdk api 에는 없지만 rt.jar 에 있는 com.sun.rowset.CachedRowSetImpl 을 이용하여
변환할수 있다. RowSet 은 ResultSet 의 기능을 모두 사용할수 있다.


...
import javax.sql.rowset.CachedRowSet;
import com.sun.rowset.CachedRowSetImpl;
...
 public void writeResultSet(ResultSet rs){
  try {
   File file = new File("d:/dev/temp/rs_tmp_22000.rs");
   
   FileOutputStream fout = new FileOutputStream(file);
      ObjectOutputStream oout = new ObjectOutputStream(fout);
      CachedRowSet crs = new CachedRowSetImpl();
      crs.populate(rs);
      oout.writeObject(crs);
      oout.close();

  } catch (IOException e) {
     e.printStackTrace();
  } catch (Exception e) {
   e.printStackTrace();
  }  
 }
...


...
public static RowSet readRs(File file){
  Object obj = null;
  try {  
   
   FileInputStream in = new FileInputStream(file);
   ObjectInputStream oin = new ObjectInputStream(in);
   obj = oin.readObject();
      oin.close();      
   
  } catch (IOException e) {
     e.printStackTrace();
  } catch (Exception e) {
   e.printStackTrace();
  }
  return (RowSet)rs;  
 }
...

"자바 프로그램에서 데이터베이스 접근은 매우 무거운 작업(heavyweight operation)이기 때문에, 메모리에 데이터를 캐싱하는 것은 어플리케이션 성능을 위한 핵심 요소가 된다. 메모리에 캐시되어 있는 데이터의 행을 위한 컨테이너로 ResultSet을 사용하길 원하는 경우, javax.sql.RowSet의 하위 인터페이스인 javax.sql.rowset.CachedRowSet을 사용할 수 있다. 이 인터페이스의 인스턴스는 데이터소스에 항상 연결되지 않고도 작업을 수행할 수 있는 능력을 제공한다. 이 기능에 더해서, 이 인터페이스는 scrollable, updatable, serializable의 기능을 지원한다. 이 기능에 더해서, spreadsheet와 같은 표 형태의 포맷으로 다른 데이터소스와도 작업할 수 있다. "
- http://network.hanb.co.kr/view.php?bi_id=1367

Posted by ukmie
,

 ‘write once run anywhere(한 번 쓰면 어디에서라도 움직인다)’라는 콘셉트의 이 구글 버전은 ‘오픈소셜(OpenSocial)’이라 불리며 공통 API와 세트다.

구글의 성명에 따르면 이 방법은 ‘다수의 소셜 네트워크에 접속할 수 있는 첫 공통 API’라고 한다.

OpenSocial 이란 간단히 얘기하면 별도의 SNS 서비스도 아닌 그냥 여러 SNS 사이트에 공통적으로 쓰일 어플리케이션을 만들 수 있는 공통(표준) API 규격이다. 요전 구글에 인수된 JotSpot 창업자 Joe Kraus가 PM으로 일궈낸 작품(?)인 OpenSocial이 의미하는 바는 의외로 크다.

 이 프로젝트에는 페이스북을 제외하고 마이스페이스, 아이밈(Imeem), 링크드인, 식스어파트(Six Apart)등의 소셜 네트워크 사이트들이 동참한다고 한다.

근데, OpenSocial API를 사용해서 우리나라에서 서비스를 하기란 상당히 힘들것 같다.
왜냐하면 OpenSocial API를 사용하려면 몇가지 제약사항이 있는데,
구글가젯을 사용해야 하는데 결국 구글 플랫폼 안에서만 사용할수 있다는 것이다.
이 OpenSocial  을 FaceBook 과 비교하면서 Windows 와 Linux 로 비교하는 글도 있던데,
Facebook의 오픈 플랫폼이 Walled Garden 이라는 점이 걸렸는데, 글도 OpenSocial Service Provider Interface 를 공개하지 않고있으니 기회면에서는 똑같이 제한적인거 아닐까.


참고사이트 :
http://code.google.com/apis/opensocial/
http://www.zdnet.co.kr/news/internet/etc/0,39031281,39162908,00.htm
http://blog.magicboy.net/409





Posted by ukmie
,
XWiki 소스를 뒤적거리던 중 이상한 넘을 발견했다.
뭐하는 녀석인가 봤더니, 경량급 IoC 컨테이너 였다. 이름하야 Plexus!! 
사전적의미는 신경계의 망 등을 의미한다고 한다. 음. 어쨌거나,
이걸 또 공부해야 하나 싶으면서도 자꾸 궁금해진다. 담에 한번 써볼까 싶다.


사용자 삽입 이미지

While Plexus is similar to other inversion-of-control (IoC) or dependency injection frameworks such as the Spring Framework, it is a full-fledged container that supports many more features such as:

  • Component lifecycles
  • Component instantiation strategies
  • Nested containers
  • Component configuration
  • Auto-wiring
  • Component dependencies, and
  • Various dependency injection techniques including constructor injection, setter injection, and private field injection.

How does Plexus compare with Spring?

- Complex component life cycles are not supported in Spring.
- Spring configuration files are much longer than the one for Plexus.
- Spring is not using IoC for all dependecies of components.
- Missing notion of "Component identity"
- Component class loader isolation.
- In Plexus you don't have to repeat yourself.


Posted by ukmie
,
광고바만 설치해놓으면 돈을 주는건가.? 음음,, 무슨 다단계 같기도 하고,
암튼 돈을 준다니깐.. 궁금하네, 그리고,
이런 기술을 그냥 웹에 포스팅할때(꼭 자기 블로그가 아니더라도) 사용할수 있다면,,
... 그럼 난장판이 되겠구나..클


출처: http://korean-agloco.blogspot.com/

AGLOCO 아글로코의 제안은 아래의 한 문장입니다: 인터넷을 여러분의 것으로 만드세요. 이제까지, 여러분들과 여타 다른 네티즌들이 웹서핑, 온라인 구매, 광고, 블로그 활동, 포스팅 등의 활동을 통해 발생하는 모든 수익은, 소수의 사람들의 것이었습니다. 하지만, 더 이상은 아닙니다!


AGLOCO는 a Global Community의 약자로서, 그 주인은 회원 여러분들(저와 당신, 그리고 잠재적인 수백만의 인터넷 사용자들)입니다. AGLOCO는 우리가 인터넷 상에서 하는 모든 활동의 가치를 계산하고, 그것을 우리에게 돌려줍니다. 사용자들은 절대 돈을 지불할 필요가 없습니다. 이미 우리가 인터넷 상에서 많은 이익을 창출하고 있으니까요.





Posted by ukmie
,

RDF의 잘쓰이는 몇가지 포맷에 대한 비교. 용도에 맞게 골라쓰자.

출처: http://www.w3.org/2000/10/swap/doc/formats


English (Very Informal)

There is person, Pat, known as "Pat Smith" and "Patrick Smith".
Pat has a pet dog named "Rover".

English Hypertext (Informal)

Here the ambiguity of terms is addressed by making the words be hypertext links.
The links may or may not work, depending on the servers involved.

Pat is a human with the names "Pat Smith" and "Patrick Smith".
Pat has a pet, a dog, with the name "Rover".

N3

@prefix : <http://www.w3.org/2000/10/swap/test/demo1/about-pat#> .
@prefix bio: <http://www.w3.org/2000/10/swap/test/demo1/biology#> .
@prefix per: <http://www.w3.org/2000/10/swap/test/demo1/friends-vocab#> .
    
:pat     a bio:Human;
     per:name "Pat Smith",
              "Patrick Smith";
     per:pet  [
         a bio:Dog;
         per:name "Rover" ] .

Directed Labeled Graph

RDF/XML

<rdf:RDF xmlns="http://www.w3.org/2000/10/swap/test/demo1/about-pat#"
    xmlns:bio="http://www.w3.org/2000/10/swap/test/demo1/biology#"
    xmlns:per="http://www.w3.org/2000/10/swap/test/demo1/friends-vocab#"
    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#">

    <bio:Human rdf:about="#pat">
        <per:name>Pat Smith</per:name>
        <per:name>Patrick Smith</per:name>
        <per:pet>
            <bio:Dog>
                <per:name>Rover</per:name>
            </bio:Dog>
        </per:pet>
    </bio:Human>
</rdf:RDF>

N-Triples

With @prefix:

@prefix : <http://www.w3.org/2000/10/swap/test/demo1/about-pat#> .
@prefix bio: <http://www.w3.org/2000/10/swap/test/demo1/biology#> .
@prefix per: <http://www.w3.org/2000/10/swap/test/demo1/friends-vocab#> .
@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>.

:pat rdf:type bio:Human.
:pat per:name "Pat Smith".
:pat per:name "Patrick Smith".
:pat per:pat _:genid1.
_:genid1 rdf:type bio:Dog.
_:genid1 per:name "Rover".

In standard form:

<http://www.w3.org/2000/10/swap/test/demo1/about-pat#pat> 
<http://www.w3.org/1999/02/22-rdf-syntax-ns#type>
<http://www.w3.org/2000/10/swap/test/demo1/biology#Human> . <http://www.w3.org/2000/10/swap/test/demo1/about-pat#pat>
<http://www.w3.org/2000/10/swap/test/demo1/friends-vocab#name> "Pat Smith" . <http://www.w3.org/2000/10/swap/test/demo1/about-pat#pat>
<http://www.w3.org/2000/10/swap/test/demo1/friends-vocab#name> "Patrick Smith" . <http://www.w3.org/2000/10/swap/test/demo1/about-pat#pat>
<http://www.w3.org/2000/10/swap/test/demo1/friends-vocab#pet> _:genid1 . _:genid1
<http://www.w3.org/1999/02/22-rdf-syntax-ns#type>
<http://www.w3.org/2000/10/swap/test/demo1/biology#Dog> . _:genid1 <http://www.w3.org/2000/10/swap/test/demo1/friends-vocab#name> "Rover" .
Posted by ukmie
,
ResultSet 클래스에는 row의 갯수를 리턴해주는 메소드가 없다.
물론 만들면 된다.
resultSet.last() 를 호출하므로
ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY
을 미리 설정해줘야 한다. (필요없는 경우도 있긴하다.)
PreparedStatement stmt = conn.prepareStatement(
query,
ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);
or
Statement stmt = connection.createStatement(
ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);

public static int getResultSetSize(ResultSet resultSet) {
    int size = -1;

    try {
        resultSet.last();
        size = resultSet.getRow();
        resultSet.beforeFirst();
    } catch(SQLException e) {
        return size;
    }

    return size;
}

Posted by ukmie
,

LinkedHashMap 를 이용하여 간단하게 LRU(leat-recently-used) 캐쉬를 구현할 수 있다.
여러가지 캐쉬 알고리즘과 솔루션들을 상황에 따라 고를 수 있지만, 간단한 캐쉬 기능이 필요한 경우
유용하게 쓸수 있다.

import java.util.LinkedHashMap;
import java.util.Collection;
import java.util.Map;
import java.util.ArrayList;
public class LRUCache<K,V> {
private static final float   hashTableLoadFactor = 0.75f;
private LinkedHashMap<K,V>   map;
private int                  cacheSize;

public LRUCache (int cacheSize) {
   this.cacheSize = cacheSize;
   int hashTableCapacity = (int)Math.ceil(cacheSize / hashTableLoadFactor) + 1;
   map = new LinkedHashMap<K,V>(hashTableCapacity, hashTableLoadFactor, true) {
      // (an anonymous inner class)
      private static final long serialVersionUID = 1;
      @Override protected boolean removeEldestEntry (Map.Entry<K,V> eldest) {
         return size() > LRUCache.this.cacheSize; }}; }
/**
* The retrieved entry becomes the MRU (most recently used) entry.
*/

public synchronized V get (K key) {
   return map.get(key); }
/**
* If the cache is full, the LRU (least recently used) entry is dropped.
*/

public synchronized void put (K key, V value) {
   map.put (key,value); }
public synchronized void clear() {
   map.clear(); }
public synchronized int usedEntries() {
   return map.size(); }
public synchronized Collection<Map.Entry<K,V>> getAll() {
   return new ArrayList<Map.Entry<K,V>>(map.entrySet());
}


// 4test..!



public static void main (String[] args) {
    LRUCache<String,String> c = new LRUCache<String,String>(3);
    c.put ("1","one");                            // 1
    c.put ("2","two");                            // 2 1
    c.put ("3","three");                          // 3 2 1
    c.put ("4","four");                           // 4 3 2
    if (c.get("2")==null) throw new Error();      // 2 4 3
    c.put ("5","five");                           // 5 2 4
    c.put ("4","second four");                    // 4 5 2
    // Verify cache content.
    if (c.usedEntries() != 3)              throw new Error();
    if (!c.get("4").equals("second four")) throw new Error();
    if (!c.get("5").equals("five"))        throw new Error();
    if (!c.get("2").equals("two"))         throw new Error();
    // List cache content.
    for (Map.Entry<String,String> e : c.getAll())
       System.out.println (e.getKey() + " : " + e.getValue());
}

} 
 
참고: http://www.source-code.biz/snippets/java/6.htm
http://dojeun.egloos.com/317868
http://java.sun.com/j2se/1.4.2/docs/api/java/util/LinkedHashMap.html

 
Posted by ukmie
,

장윤석/SAS코리아 차장

EDW(Enterprise Data Warehouse)는 기존 DW(Data Warehouse)를 전사적으로 확장한 모델인 동시에 BPR과 CRM, BSC 같은 다양한 분석 애플리케이션들을 위한 원천이 된다. 따라서 EDW를 구축하는 것은 단순히 정보를 빠르게 전달하는 대형 시스템을 도입한다는 의미가 아니라 기업 리소스의 유기적 통합, 다원화된 관리 체계 정비, 데이터의 중복 방지 등을 위해 시스템을 재설계 하는 것으로 이해해야 한다.
데이터 웨어하우징(Data Ware-housing)의 개념은 기간계의 주요 데이터를 주제별로 통합하여 현업 부서의 정보분석 요구를 신속히 충족시키는 시스템을 의미한다. 이를 위해 기업의 정보기반이 되는 인프라를 구축하고 이를 IT부서의 도움 없이 액세스하는 방법을 제공하게 된다. EDW는 이 개념을 기업의 전사적인 영역으로 확장시킨 개념이라고 볼 수 있다.
그렇다면 EDW의 범주를 어디까지 보아야 할까? 기업에서 최근 일반적으로 구성되는 표준 모델의 형태는 <그림>과 같다.

<그림>에서 보면 이전과 같이 전면에 포지셔닝 되는 그림이 아닌 BI(Business Intelligence) 애플리케이션을 위한 데이터 인프라로서의 역할이 강조되는 것을 확인할 수 있다. 이와 같이 EDW란 것은 이전의 DW를 전사적으로 확장하려고 하는 부분에서 생긴 다양한 시스템간의 인터페이스와 데이터 통합, 표준화 등을 중요시한 DW의 확장 모델인 동시에 기업 정보에 관한 프로세스의 표준화와 개선, 즉 BPR적 영역을 포함한다. 또한 CRM, BSC 같은 다양한 분석적 애플리케이션들을 위한 데이터의 원천이 된다.

EDW의 출현 배경

IT시장에 DW의 개념이 나오고 일반화된지 거의 10년이 되어가고 있지만 초기의 정의와 역할과는 다르게 최근 DW의 의미는 거의 분석계 플랫폼의 전체를 지칭하는 명사로 인식되고 있다. 단순히 데이터를 주제별로 통합해 OLAP 시스템을 통한 다차원의 분석을 가능케 하는 초기 정의와는 달리 2000년대 들어서는 정제되고 통합된 데이터를 거의 모든 BI 애플리케이션(ABM, BSC, CRM 등)에게 제공해 주는 데이터 인프라 측면이 강조되었다.
이에 따라 ABM, BSC, 혹은 CRM 프로젝트란 이름 하에 각 시스템의 분석 마트를 설계하는 프로젝트들이 진행되어 왔다. 또한 근래에 들어서는 RTE(Real Time Enterprise), EAI와의 연동을 통한 좀더 기술적, 비즈니스적으로 진보된 플랫폼으로 구축하려는 시도를 보이고 있다.
사실 처음 EDW란 용어가 시장에 나왔을 때 당혹해 하는 사람들도 많았을 것이다. DW 시장 도입 초기단계에서는 시스템 발전에 따른 비용부담의 감소로 인해 이전에 할 수 없었던 대용량의 데이터 분석이 가능해졌고, 이로 인해 기업 내 데이터의 전사적인 인프라 구축과 정보 조회가 가능하다고 소개를 했다.
하지만 이후 단순한 데이터만으로는 사용자의 다양한 구미에 맞는 모든 경우의 주제 모델링이 불가능해지자 각각의 목적에 맞게 데이터 마트를 구축하는 것이 흐름으로 이어져 새로운 DW 구축 프로젝트를 만들어 나가기 시작했다. 그러나 데이터 마트도 기본적으로는 DW를 잘 설계했다면 불필요한 모델이었을 것이다.
그 러나 중요한 것은 각 벤더의 이해가 달린 새로운 개념의 출현이 아니다. 새로운 개념이 출현했다고 해서 꼭 그것을 반영하고 도입해야 할 이유도 없고, 그것이 정답이 될 수도 없기 때문이다. 중요한 것은 각 기업의 상황에 맞는 가장 적절하고 유용한 시스템을 구축하는 것이다. 이는 DW 도입의 초기 단계에서부터 줄곧 주장되어 온 것으로 현재의 상황에서도 적합한 말이다. 단지 그것이 확장되고 진보되었을 뿐이다.
DW가 한 순간의 유행으로 끝나지 이유는 기업의 정보 데이터 인프라를 구축하는 최적의 개념이고 필수적인 요소이기 때문이다.

EDW의 이슈와 과제

각 컨설팅업체와 벤더들 사이에서 EDW에 대한 나름의 이론을 내놓고 있다. 기업 운영 과정에서 생산되는 전체 데이터를 한 통에 남김없이 모두 적재해 데이터의 중복을 방지하고 동기화를 보장해야 한다거나, 여러 종류의 마트 중심으로 데이터를 구축하는 것이 차후의 여러 BI 시스템의 확장에 유연하게 대처할 수 있다는 등 벤더 위주의 정의들을 내리고 있다.
그러나 실제 이상주의적인 개념들과는 달리 현실 세계에서의 EDW 구축에서는 정답이 없다는 것이 필자의 생각이다. 실제로 많은 회사에서 DW를 구축했고, 부서 단위의 분석 마트를 운영하며, 업무의 효율을 높이기 위해 노력하고 있다,
이들 또한 데이터들의 전사적인 관리와 통합이라는 측면에서 EDW 프로젝트를 준비하고 있는 것이 사실이다. 그러나 실제 EDW 프로젝트가 수행된 결과물을 보면, 단지 지금까지 있었던 DW를 크게 만들어 놓은 것과 크게 다르지 않아 보인다. I/O를 확장하고, 모델이 전사 영역으로 확장되고, CRM 등의 프론트 오피스를 하나 얹어 놓는 등의 형태로 구축되는 것이 현재 거의 모든 사이트에서 진행되는 EDW의 형태인 것이다.
물론 전사영역으로 확장하는 것만으로도 충분히 많은 경비와 인력과 노력을 요하는 것은 사실이다. 그러나 과연 이것이 EDW의 전부일까? 물리적으로 데이터를 모아놓는다는 측면에서만 생각하면 이같은 형태를 EDW라고 할 수도 있지만 진정한 기업의 인프라로서의 EDW란 데이터 측면만으로 부족하다.
기업 데이터를 하나의 분석플랫폼에 모아놓으려는 의도는 무엇인가? 모든 데이터의 접근성을 용이하게 하고, 각 데이터의 주제적 연관성을 보장하여 기업이 가진 정보의 가치를 높이는 것이 EDW라 하면 이 작업은 데이터의 수집만이 아닌 프로세스 개선과 POS에서 백오피스, 분석계까지의 모든 데이터 표준화와 동기화를 말하는 것이다.
이를 위해 필요한 것은 몹시 크고 빠른 공룡 같은 새로운 시스템을 도입하는 것이 아니다. 기업들이 모든 리소스들의 아키텍처 개선을 통한 유기적인 통합과 다원화된 관리 체계를 재정비하여 불필요하게 낭비되는 관리비용을 줄이고, 데이터의 중복을 방지할 수 있는 방향으로 시스템을 재설계 하는 것이 EDW의 중요한 초석일 것이다.
EDW의 기술적 문제점 시스템이 빨라지고 가격이 낮아져 대용량의 데이터를 처리할 수 있게 됐다고 하지만 그 속도에 맞추어 분석에 대한 요구도 복잡해지고, 데이터의 수도 크게 늘어난 것이 사실이다. 이에 따라 DW의 초기부터 논의되고 시간이 지나면 해결될 것으로 봤지만 여전히 해결되지 않고 있는 부분이 몇 가지 있다.
우선 추출에서의 Real Time, 즉 실시간 데이터 처리 문제와 인덱스의 발전에도 불구하고 수GB 이상의 테이블 간 결합을 통한 대량의 데이터 분석 문제, DRS 등으로 표현되는 백업과 복구에 관한 문제 등이 그것이다. 특히 EDW에서는 이와 같은 처리의 중요성이 더욱 부각되고 있지만 현재 시장에 나와 있는 기술로는 완벽한 해결책을 제시하지 못하고 있다.
실시간 처리의 대안으로 EAI 또는 DB의 로그를 처리하는 기술이 부각되고 있지만, 이 역시 많은 코딩을 필요로 하고 실시간으로 요약 데이터에 반영해줄 수는 없다. 실제 OLTP를 사용하는 것과 같은 EDW에 변경 분을 반영하는 것은 적어도 향후 5년 정도 뒤에나 가능할 것으로 보인다.
또한 대량의 트랜잭션을 처리하는 기업과 통신사의 콜 데이터나 은행의 트랜잭션들은 발전된 하드웨어의 속도가 무색할 정도로 증가하고 있다. 하루에도 수십 GB씩 쌓이는 이들 데이터를 처리하고 분석하기 위해 파티션 기법, 비트맵 인덱싱들의 기술들이 사용되고 있으나 근본적인 문제의 해법을 제시해 주지 못하고 있다.
한편 백업의 경우에는 각 DB 벤더들이 솔루션을 보유하고 있고, 나름의 복구 방안을 제시하고 있지만 사용이 어렵고 신뢰성도 부족하기 때문에 전체 파일 시스템의 백업 방법을 쓰고 있는 회사가 대부분이다.
EDW 는 그 기술의 근간을 RDBMS에 두고 있다. 이는 분석의 한계 역시 SQL의 영역에 국한됨을 의미한다. 이러한 약점에 따라 이전의 OLTP용 DB를 사용할 경우는 MOLAP을 DW의 부가적인 분석을 제공하는 시스템으로 구축하고 마트를 만들어 왔다.
그 러나 분석 전용 DB의 등장과 ROLAP 툴의 발달로 MOLAP은 서서히 그 효용가치를 잃어가고 있는 상황이다. 그러나 이와 같은 관계형 DB기술의 발달에도 불구하고, 여전히 관계형 DBMS는 사용자의 고차원적인 분석 욕구를 해결해 주지 못하고 있는 것 또한 현실이다.

EDW 시장 동향

근래 들어 전 산업에 걸쳐 고르게 EDW의 수요가 증가하고 있다. 작년 한해 동안 금융권에서는 조흥은행, 우리은행, 국민은행 등이 구축을 완료하거나 현재 진행 중이고 현대카드, 신용보증기금, 대한생명, 농협, 교보생명, 우리증권 등이 올해 신규로 EDW를 준비중이다. 또 제조·유통 쪽에서는 롯데백화점, 신세계 이마트, 제일모직, LG패션 등이 지난해 구축을 완료했거나 현재 진행 중이다.
통신산업에서는 KT가 현재 전사적인 EDW를 진행 중이고, 정보통신부도 각각의 업무 부서별로 여러 건의 DW 프로젝트가 진행 중이거나 신규도입을 준비하고 있다. 이외에도 연세의료원, 건국대 병원 등 많은 종합 병원들이 올해 DW의 도입을 계획하고 있는 상황이다.
근래에 와서 BI 애플리케이션의 수요가 증가하고 있다. 이는 기존의 모델링 방법론의 실패 요인을 줄이는 한편 각 인더스트리의 선진 기술에 프로세스를 맞추어 개발 기간을 단축하고, 많은 부분이 표준화되어 있는 리포지토리를 도입해 업무의 효율을 높이려는 시도라고 볼 수 있다.
그렇다면 높은 비용에도 불구하고 OLAP 툴을 쓰는 이유는 무엇일까? 이는 기존의 OLTP 시스템 개발과 같이 충분히 개발을 할 수 있는 기술이 있음에도 미리 개발되어 있는 컴포넌트들을 사용함으로써 빠른 시간에 프로젝트를 완료하고, 완성도 높은 분석을 제공하기 위함이다.
이러한 BI 애플리케이션들이 아무리 좋은 선진 프로세스와 첨단 기능을 제공한다할 지라도 기존 분석의 근간이 되는 데이터가 부족하고 데이터의 신뢰성이 없다면 또 하나의 유행에 의한 시스템이 될 뿐이다.
이러한 문제의식은 기반 데이터의 통합과 정제라는 기본에서 출발해야 하는 공통의 인식을 가지게 하였고, 거의 모든 기업에서 EDW는 필수적인 정보인프라로 자리매김하게 된 것이다.
또한 기존에 EDW를 구축한 기업에서는 고도화를 통해 새로운 활용처를 모색하게 되었고, 보다 고급화되고 정밀한 분석을 위해 즉시성의 데이터 요구가 생기게 되었다.
이 를 위해 기존의 일 배치나 월 배치의 형태에서 벗어나 데이터의 업데이트 주기를 최소화하는 Near Real Time 처리 방법에 대한 논의가 활발하게 이루어지고 있으며 기존의 DW, OLAP의 분석으로 만족할 수 없었던 집단(마케팅이나 정보분석실과 같은 부서)을 위해 IT의 주도 하에 이루어지던 주제 영역의 모델링, 데이터 조작 등의 작업 주도권과 사용권한을 사용자에게 줄 수 있는 고급분석 시스템에 대한 요구가 증가하고 있다.

제공 : DB포탈사이트 DBguide.net

Posted by ukmie
,
몇가지 방법이 있지만 이게 젤 편한것 같다. 근데도 맨날 까먹는다.--
또다른방법:http://radiocom.kunsan.ac.kr/lecture/mysql/user_add.html
MySQL매뉴얼: http://www.mysqlkorea.co.kr/sub.html?mcode=develop&scode=01&lang=k

mysql> create database ontowiki;
Query OK, 1 row affected (0.01 sec)

mysql> grant all on ontowiki.* to ontowiki@localhost identified by 'xxx'
    -> with grant option;
Query OK, 0 rows affected (0.01 sec)

Posted by ukmie
,
J2EE 개발 관련 아티클은 많긴 하지만, OTN에 괜찮은 연재가 있어 정리 해놓는다.
실전적인 글 위주이고 다양한 주제를 다루고 있어 유용해 보인다.

Mastering J2EE Application Development

개방형 표준이 IT 소프트웨어 인프라스트럭처의 흐름을 주도하고 있습니다. 그 중에서도 개방형 표준의 중심에 서 있는 것이 바로 J2EE입니다. 여러 주에 걸쳐 연재되는 이번 시리즈를 통해, OTN은 프로젝트 도입에서 최종 구축에 이르는 전체 J2EE 개발 라이프사이클을 단순화하는 데 관련한 기술적 이슈를 총체적으로 짚어봅니다. 특히, J2EE의 기반을 마련한J2EE 전문가 들과 엔지니어들의 실제 경험이 상세하게 소개되며, 오라클 제품을 이용하여 직접 구현할 수 있는 예제가 포함됩니다. 모델링, 디자인, 디버깅 테크닉, 코드 최적화 및 프로파일링 등 다양한 주제에 걸쳐 논의가 전개됩니다.

1부: J2EE의 해부(Slicing and Dicing J2EE)
Ted Neward, Effective Enterprise Java 저자

애플리케이션의 요구사항을 정확하게 이해하는 것은 J2EE의 복잡성을 완화하는 데 크게 도움이 됩니다.
...

개발자들은 지나치게 넓은 선택의 폭을 강요 받고 있습니다

...

엔터프라이즈” Java 애플리케이션에는 기본적으로 다섯 가지 종류(stovepipe, jewel, aggregator, integrator, enterprise app)가 존재합니다.

...

2부: 프로젝트의 관리
Julien Dubois, Senior J2EE Developer

프로젝트 관리 툴과 베스트 프랙티스를 선택하는 것은 프로젝트 관리자가 결정해야 하는 가장 중요한 문제의 하나입니다. (with Maven)

3부: 설계와 모델링(설계는 먼저, 코딩은 나중에)
Scott W.Ambler, Senior Consultant, Ronin International

UML(Unified Modeling Language) 다이어그램을 이용한 다양한 테크닉을 활용하여 J2EE 애플리케이션을 효과적으로 모델링할 수 있습니다.

4부: 프레임워크 기반의 구축(프레임워크를 이용한 J2EE 테크놀로지의 보완)
Rashmi Sinha (Ph.D) and Jonathan Boutelle, Principal, Uzanto Consulting

JSF 호환 Oracle ADF Faces 프레임워크가 제공하는 컴포넌트들을 활용하여 복잡한 Web UI를 구현하는 방법에 대해 알아봅니다.

5부: 프레임워크 기반의 구현(애플리케이션 사용성을 고려한 설계)
Andrei Cioroianu, Founder of Devsphere

소프트웨어 개발 프로세스에 사용성 분석(usability analysis) 과정을 도입함으로써, 향후 발생되는 변경 요구사항에 쉽게 대응할 수 있습니다.

6부: 서버-사이드 Java 마스터하기(JMS 기반 Object Cache를 이용한 성능 향상)
Rod Johnson, co-author, Spring Framework; and James Clark, Oracle TopLink Development.

J2EE 클러스터에서 서버 간에 in-memory cache를 동기화하는 방법을 사용하여 server-side Java 애플리케이션의 성능과 확장성을 향상시킬 수 있습니다.

7부: 사용자 인터페이스의 설계
Venkat Tipparam, Oracle Java Developer of the Year 2004

기능성과 사용편의성이 뛰어난 웹 애플리케이션 인터페이스를 구현하는 방법을 알려 드립니다.

8부: 사용자 인터페이스의 설계 (2부-장점의 조합: J2EE 애플리케이션의 JSF-Struts 통합)
Hans Bergsten, member JCP expert groups, and Author of JavaServer Faces (O’Reilly)

Struts 애플리케이션에 JavaServer Faces 컴포넌트를 추가하는 방법을 설명합니다.

9부: 서버-사이드 Java 마스터하기(2부-Persistence와 POJO: 오브젝트 및 관계형 모델의 통합)
Craig McClanahan, Creator of Struts

Oracle TopLink와 Spring의 DAO layer를 함께 활용하여 Plain Old Java Object의 persistence를 구현하고 높은 성능과 생산성을 확보할 수 있습니다.

10부: 디버깅 테크닉 마스터하기(Breakpoint의 정복)
Satadip Dutta, Software Architect, Hewlett-Packard

Java 애플리케이션의 디버깅을 위한 프로그램적인 메커니즘을 설명하고, 버그의 근본 원인을 확인하기 위해 stack trace를 이용하는 방법을 설명합니다.

11부: 최적화 및 프로파일링(Memory Leak의 확인)
Benjamin Livshits, Ph.D. candidate, Stanford University

Memory profiling과 heap debugging을 이용하여 listener pattern의 사용 등으로 인해 초래되는 memory leak 문제를 방지하는 방법을 설명합니다.

12부: 구축(Deployment: 개발 작업의 완결)
Lonneke Dikmans, Senior Consultant, Transfer Solutions

deployment profile과 Ant를 이용하여 다수의 애플리케이션 서버에 J2EE 애플리케이션을 deploy하는 방법을 설명합니다.

12-1부: 구축(Deployment: 개발 작업의 완결-2부)
Lonneke Dikmans, Senior Consultant, Transfer Solutions


Commentary: The State of J2EE
Peter Zadrozny, Vice President & Chief Evangelist, Oracle Application Server
Trends in J2EE computing and key technologies to watch

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Posted by ukmie
,