오라클과 프로그램간에 배열을 어떻게 주고 받을 것이지
고민해 보신 분들이 계실 줄 압니다.
며칠간 시간이 나서 이리저리 찾아보니까..다음처럼 결과물이 나왔네요...
사실 몇 달 전부터 한 번 봐야 쓰겄다 했는데...이제사 조금 감을 잡았습니다.
실제적으로 프로젝트에 적용해본 적은 없고..테스트로 해 본 내용입니다.
필요한 상황에 맞게 응용을 해보시면 될 성 싶습니다.
제가 능력많아..떡하니 이렇게 작품을 내놓으면 좋겠지만......
애석하게도.. http://asktom.oracle.com/pls/ask/f?p=4950:1: 에서 자료참조를 했습니다.
1. Java Stored Procedure "ArrayDemo" 생성
create or replace
and compile java source named "ArrayDemo"
as
import java.io.*;
import java.sql.*;
import oracle.sql.*;
import oracle.jdbc.driver.*;
public class ArrayDemo
{
public static void passArray() throws SQLException
{
Connection conn = new OracleDriver().defaultConnection();
int intArray[] = { 1,2,3,4,5,6 };
ArrayDescriptor descriptor = ArrayDescriptor.createDescriptor( "NUM_ARRAY",
conn);
ARRAY array_to_pass = new ARRAY( descriptor, conn, intArray );
OraclePreparedStatement ps =
(OraclePreparedStatement)conn.prepareStatement( "begin give_me_an_array
(:x); end;" );
ps.setARRAY( 1, array_to_pass );
ps.execute();
}
}
/
Java created.
2. 사용할 Array(or TYPE) 생성
create or replace type NUM_ARRAY as table of number;
/
Type created.
3. Array 출력시키는 Procedure 생성
create or replace procedure give_me_an_array( p_array in num_array )
as
begin
for i in 1 .. p_array.count
loop
dbms_output.put_line( p_array(i) );
end loop;
end;
/
Procedure created.
4. java source를 호출하는 Procedure 생성
create or replace procedure show_java_calling_plsql
as language java
name 'ArrayDemo.passArray()';
/
Procedure created.
5. Procedure "give_me_an_array"에서 출력하는 내용을 보기 위한 명령어
set serveroutput on
6. show_java_calling_plsql 실행
exec show_java_calling_plsql
결과>
1
2
3
4
5
6
고민해 보신 분들이 계실 줄 압니다.
며칠간 시간이 나서 이리저리 찾아보니까..다음처럼 결과물이 나왔네요...
사실 몇 달 전부터 한 번 봐야 쓰겄다 했는데...이제사 조금 감을 잡았습니다.
실제적으로 프로젝트에 적용해본 적은 없고..테스트로 해 본 내용입니다.
필요한 상황에 맞게 응용을 해보시면 될 성 싶습니다.
제가 능력많아..떡하니 이렇게 작품을 내놓으면 좋겠지만......
애석하게도.. http://asktom.oracle.com/pls/ask/f?p=4950:1: 에서 자료참조를 했습니다.
1. Java Stored Procedure "ArrayDemo" 생성
create or replace
and compile java source named "ArrayDemo"
as
import java.io.*;
import java.sql.*;
import oracle.sql.*;
import oracle.jdbc.driver.*;
public class ArrayDemo
{
public static void passArray() throws SQLException
{
Connection conn = new OracleDriver().defaultConnection();
int intArray[] = { 1,2,3,4,5,6 };
ArrayDescriptor descriptor = ArrayDescriptor.createDescriptor( "NUM_ARRAY",
conn);
ARRAY array_to_pass = new ARRAY( descriptor, conn, intArray );
OraclePreparedStatement ps =
(OraclePreparedStatement)conn.prepareStatement( "begin give_me_an_array
(:x); end;" );
ps.setARRAY( 1, array_to_pass );
ps.execute();
}
}
/
Java created.
2. 사용할 Array(or TYPE) 생성
create or replace type NUM_ARRAY as table of number;
/
Type created.
3. Array 출력시키는 Procedure 생성
create or replace procedure give_me_an_array( p_array in num_array )
as
begin
for i in 1 .. p_array.count
loop
dbms_output.put_line( p_array(i) );
end loop;
end;
/
Procedure created.
4. java source를 호출하는 Procedure 생성
create or replace procedure show_java_calling_plsql
as language java
name 'ArrayDemo.passArray()';
/
Procedure created.
5. Procedure "give_me_an_array"에서 출력하는 내용을 보기 위한 명령어
set serveroutput on
6. show_java_calling_plsql 실행
exec show_java_calling_plsql
결과>
1
2
3
4
5
6
[이 게시물은 관리자님에 의해 2011-10-31 16:47:36 Oracle에서 이동 됨]
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 1530 |
1111111
|
18년 전 | 1953 | |
| 1529 |
행복속네잎크로버
|
18년 전 | 3454 | |
| 1528 |
행복속네잎크로버
|
18년 전 | 1831 | |
| 1527 |
1111111
|
18년 전 | 7639 | |
| 1526 |
1111111
|
18년 전 | 3285 | |
| 1525 |
행복속네잎크로버
|
18년 전 | 1269 | |
| 1524 |
행복속네잎크로버
|
18년 전 | 2301 | |
| 1523 |
행복속네잎크로버
|
18년 전 | 3504 | |
| 1522 |
행복속네잎크로버
|
18년 전 | 2359 | |
| 1521 |
행복속네잎크로버
|
18년 전 | 2135 | |
| 1520 |
행복속네잎크로버
|
18년 전 | 2762 | |
| 1519 |
행복속네잎크로버
|
18년 전 | 3719 | |
| 1518 |
행복속네잎크로버
|
18년 전 | 3484 | |
| 1517 |
행복속네잎크로버
|
18년 전 | 2566 | |
| 1516 |
행복속네잎크로버
|
18년 전 | 1912 | |
| 1515 |
행복속네잎크로버
|
18년 전 | 1931 | |
| 1514 |
행복속네잎크로버
|
18년 전 | 2509 | |
| 1513 |
행복속네잎크로버
|
18년 전 | 1983 | |
| 1512 | 18년 전 | 2868 | ||
| 1511 | 18년 전 | 1662 | ||
| 1510 | 18년 전 | 2206 | ||
| 1509 | 18년 전 | 1680 | ||
| 1508 | 18년 전 | 2137 | ||
| 1507 | 18년 전 | 2357 | ||
| 1506 | 18년 전 | 2295 | ||
| 1505 | 18년 전 | 2247 | ||
| 1504 | 18년 전 | 2177 | ||
| 1503 | 18년 전 | 3486 | ||
| 1502 | 18년 전 | 1667 | ||
| 1501 | 18년 전 | 3441 | ||
| 1500 | 18년 전 | 2025 | ||
| 1499 | 18년 전 | 5294 | ||
| 1498 | 18년 전 | 2153 | ||
| 1497 |
hsp1980
|
18년 전 | 2334 | |
| 1496 |
hsp1980
|
18년 전 | 1726 | |
| 1495 |
hsp1980
|
18년 전 | 2133 | |
| 1494 |
hsp1980
|
18년 전 | 3649 | |
| 1493 | 18년 전 | 1501 | ||
| 1492 | 18년 전 | 1742 | ||
| 1491 | 18년 전 | 4320 | ||
| 1490 | 18년 전 | 3706 | ||
| 1489 | 18년 전 | 3263 | ||
| 1488 | 18년 전 | 3365 | ||
| 1487 |
mixdesign
|
18년 전 | 3868 | |
| 1486 |
mixdesign
|
18년 전 | 4326 | |
| 1485 | 18년 전 | 4249 | ||
| 1484 | 18년 전 | 2700 | ||
| 1483 |
hsp1980
|
18년 전 | 2309 | |
| 1482 |
hsp1980
|
18년 전 | 3246 | |
| 1481 |
hsp1980
|
18년 전 | 3163 | |
| 1480 |
hsp1980
|
18년 전 | 3317 | |
| 1479 | 18년 전 | 3256 | ||
| 1478 |
|
18년 전 | 4921 | |
| 1477 |
|
18년 전 | 5207 | |
| 1476 | 18년 전 | 3406 | ||
| 1475 |
mixdesign
|
18년 전 | 2721 | |
| 1474 |
mixdesign
|
18년 전 | 2939 | |
| 1473 |
mixdesign
|
18년 전 | 2267 | |
| 1472 |
mixdesign
|
18년 전 | 2085 | |
| 1471 |
mixdesign
|
18년 전 | 2038 | |
| 1470 |
|
18년 전 | 3073 | |
| 1469 |
mixdesign
|
18년 전 | 2355 | |
| 1468 |
mixdesign
|
18년 전 | 2374 | |
| 1467 |
mixdesign
|
18년 전 | 2053 | |
| 1466 |
mixdesign
|
18년 전 | 2420 | |
| 1465 |
mixdesign
|
18년 전 | 3152 | |
| 1464 | 18년 전 | 4082 | ||
| 1463 | 18년 전 | 3372 | ||
| 1462 |
|
18년 전 | 1998 | |
| 1461 |
|
18년 전 | 1941 | |
| 1460 | 18년 전 | 2857 | ||
| 1459 | 18년 전 | 1651 | ||
| 1458 |
|
18년 전 | 2004 | |
| 1457 |
mixdesign
|
18년 전 | 2296 | |
| 1456 |
mixdesign
|
18년 전 | 2161 | |
| 1455 | 18년 전 | 2266 | ||
| 1454 | 18년 전 | 4037 | ||
| 1453 | 18년 전 | 1773 | ||
| 1452 | 18년 전 | 4390 | ||
| 1451 | 18년 전 | 2923 | ||
| 1450 | 18년 전 | 2218 | ||
| 1449 | 18년 전 | 3267 | ||
| 1448 | 18년 전 | 2898 | ||
| 1447 | 18년 전 | 2825 | ||
| 1446 | 18년 전 | 5632 | ||
| 1445 | 18년 전 | 2292 | ||
| 1444 | 18년 전 | 3409 | ||
| 1443 |
|
18년 전 | 3323 | |
| 1442 | 18년 전 | 3713 | ||
| 1441 | 18년 전 | 3264 | ||
| 1440 | 18년 전 | 2443 | ||
| 1439 | 18년 전 | 2090 | ||
| 1438 | 18년 전 | 2542 | ||
| 1437 | 18년 전 | 6111 | ||
| 1436 | 18년 전 | 2732 | ||
| 1435 | 18년 전 | 4545 | ||
| 1434 | 18년 전 | 2042 | ||
| 1433 | 18년 전 | 10032 | ||
| 1432 | 18년 전 | 2478 | ||
| 1431 |
Psychedelico
|
18년 전 | 1544 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기