메뉴 건너뛰기

tnt_db

Oracle java에서 array처리 방법

운영자 2003.01.27 15:48 조회 수 : 6189 추천:36

import java.io.*;
import java.sql.*;
import oracle.sql.*;
import oracle.jdbc.driver.*;

public class ArrayDemo
{
public static void main(String[] args) throws SQLException {

DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());

    Connection conn =
         DriverManager.getConnection("jdbc:oracle:thin:@210.102.97.18:1521:v880","ihjdbmgr", "ihjdbmgr01");

//    Object objArray1[][] = {{"Ha"},{"Kweon"},{"Park"}};

    Object objArray1[] = {"Ha1","12345678901231"};
    Object objArray2[] = {"Ha2","12345678901232"};
    Object objArray3[] = {"Ha3","12345678901233"};

        Object objArray[] = new Object[3];

    StructDescriptor        desc1 =          StructDescriptor.createDescriptor("STUD_BUFFER",conn);
    ArrayDescriptor                desc2 =   ArrayDescriptor.createDescriptor( "STUD_ARRAY", conn);

        STRUCT pstruct = null;

        pstruct = new STRUCT(desc1, conn, objArray1);
        objArray[0] = pstruct;
        pstruct = new STRUCT(desc1, conn, objArray2);
        objArray[1] = pstruct;
        pstruct = new STRUCT(desc1, conn, objArray3);
        objArray[2] = pstruct;

    ARRAY array_to_pass = new ARRAY( desc2, conn, objArray );

/*
        int i = 0;
        for (i=0;i < 3 ;i++ )
        {
                System.out.println(i+" : "+array_to_pass[i].toString());
        }
*/


        System.out.println(array_to_pass.getOracleArray());


    OraclePreparedStatement ps =
        (OraclePreparedStatement)conn.prepareStatement
        ( "begin batchUpdate(:x,:x2,:x3); end;" );

    ps.setARRAY( 1, array_to_pass );        // 처리될 배열

        ps.setInt( 2, 3);                                // 처리될 개수
        ps.setString( 3, "2003");                        // 학년도
        
    ps.execute();

}

}




/*

drop type STUD_BUFFER;

drop type STUD_ARRAY

-- update용 type선언
create or replace type STUD_BUFFER as object(sorted_rank varchar2(30), gupsu_no varchar2(10));

-- 실행
create or replace type STUD_ARRAY as table of STUD_BUFFER;


procedure give_me_an_array( p_array in num_array, p_count in number )
as
begin
      for i in 1 .. p_count
      loop
          dbms_output.put_line(p_array(i).name);
          insert into emp2(name) values (p_array(i).name);
          commit;
      end loop;
end;
*/
번호 제목 글쓴이 날짜 조회 수
74 TABLE,COLUMN,PROCEDURE 이름을 확인할때... 원우석 2006.03.10 3114
73 NESTED TABLE과 VARRAY사용법과 다른점 박상현 2005.11.03 8834
72 plan table(sql실행계획) 보는 select문 운영자 2003.01.28 3988
» java에서 array처리 방법 운영자 2003.01.27 6189
70 효율적인 25가지 SQL작성법 운영자 2003.01.04 2948
69 중복 data는 처음에만 display 하게 하는 방법 운영자 2002.11.23 2965
68 중복 data를 찾아 한번만 display하는 방법 운영자 2002.11.23 3428
67 중복 data를 찾아 모두 display 하는 방법 운영자 2002.11.23 3070
66 oracle의 procedure에서의 여러 리턴값의 활용 예 운영자 2002.10.18 8301
65 특정문자까지의 왼쪽 문자열 반환 function 운영자 2002.10.18 4044
64 중복자료 확인 및 삭제 운영자 2002.09.25 3259
63 RECORD단위 DATA를 COLUMN단위로 운영자 2002.09.18 3681
62 누계 COLUMN이 없는 TABLE에 누계 값을 보자 (부등호 JOIN) 운영자 2002.09.18 5104
61 바로이전 ROW의 값을 참조하고자 할때 운영자 2002.09.18 8619
60 누계 COLUMN이 없는 TABLE에 누계 값을 보자 (IN-LINE VIEW) 운영자 2002.09.18 3123
59 자기보다 작은값중 최대값 하나만 읽어오기 운영자 2002.09.18 4588
58 DATA COPY를 이용한 QUERY 운영자 2002.09.18 3186
57 PARAMETER값 변경에따른 유연한 GROUP BY 운영자 2002.09.18 4127
56 PAIRWISE 와 NONPAIRWISE 운영자 2002.09.18 2697
55 동일한 값 안보여주기 운영자 2002.09.18 2969
위로