Brug eksterne Oracle-tabeller.
Se også f.eks.
- OraFaq om eksterne tabeller
- Hvad synes Tom om eksterne tabeller
- René Nyffeneggers noter om eksterne tabeller
Et simpelt eksempel, der burde få dig i gang
Du skal bruge en fil, der er placeret i et serverbibliotek (bliv fortrolig med biblioteksobjekter):
SQL> select directory_path from all_directories where directory_name = 'JTEST';
DIRECTORY_PATH
--------------------------------------------------------------------------------
c:\data\jtest
SQL> !cat ~/.gvfs/jtest\ on\ 192.168.xxx.xxx/exttable-1.csv
1,a
3,bsdf
4,sdkfj
5,something
129,else
Opret en ekstern tabel:
create table so13t (
id number(4),
data varchar2(20)
)
organization external (
type oracle_loader
default directory jtest /* jtest is an existing directory object */
access parameters (
records delimited by newline
fields terminated by ','
missing field values are null
)
location ('exttable-1.csv') /* the file located in jtest directory */
)
reject limit unlimited;
Nu kan du bruge alle kræfterne i SQL for at få adgang til dataene:
SQL> select * from so13t order by data;
ID DATA
---------- ------------------------------------------------------------
1 a
3 bsdf
129 else
4 sdkfj
5 something