oracle导入平面文件,oracle导出平面文件

这是一个Oracle PL/SQL程序包,用于将查询结果导出到平面文件,并创建控制文件以便重新加载数据到Oracle表。程序包包含一个主函数`run`,它接受查询SQL、目标表名、重载模式、目录、文件名、字段分隔符、包围字符和行终止符作为参数。此外,还包含了辅助函数如`dump_ctl`来生成控制文件,`quote`来处理字段引号,以及处理不同平台行结束符的逻辑。
摘要由CSDN通过智能技术生成

一下是代码,新建了一个程序包:

create or replace package expfile

authid current_user

as

/*将查询获得的数据导出到平面文件,创建控制文件,用以重新加载数据到oracle表中

p_query = 查询sql语句,该语句的查询的结果会被卸载到平面文件

p_tname = 需要load数据的表

p_mode = 重新加载的模式replace|append|truncate

p_dir = ctl(控制文件)和dat(数据文件)写入的目录

p_filename = 写入的文件名,后缀名.ctl和.dat分别表示控制文件和数据文件

p_separator = 字段分隔符。默认为一个逗号

p_enclosure = 定义要被分装进字段的内容,比如换行符、制表符

p_terminator = 行结束标记,默认为"|\n"on unix或者"|\r\n".你需要将此重写。

*/

function run(p_query in varchar2,

p_tname in varchar2,

p_mode in varchar2 default 'REPLACE',

p_dir in varchar2,

p_filename in varchar2,

p_separator in varchar2 default ',',

p_enclosure in varchar2 default '"',

p_terminator in varchar2 default '|')

return number;

end;

create or replace package body expfile

As

/*

g_theCursor 打开一个游标,并且返回一个整型。

g_descTbl  是一个PL/SQL表,将保存dbms_sql.desc_tab调用的输出

g_nl   换行符,在需要内嵌有换行符的串中会使用这个变量。

*/

g_theCursor integer default dbms_sql.open_cursor;

g_descTbl   dbms_sql.desc_tab;

g_nl             varchar2(2) default chr(10);

/*函数将字符转换为一个十六进制数*/

function to_hex(p_str in varchar2) return varchar2

is

begin

return to_char(ascii(p_str),'fm0x');

end;

/*对系统平台进行判断,如果是windows,行结束符就是一个两字符的串,而大多数其他

平台上的行结束符只是单字符。dbms_utility程序包get_parameter_value函数可以读取所有函数

读取了control_files参数,并查找其中是否存在\,如果有,则说明在windows平台

*/

function is_windows return boolean

is

l_cfiles varchar2(4000);

l_dummy  number;

begin

if(dbms_utility.get_parameter_value('control_files',l_dummy,l_cfiles)>0)

then

return instr(l_cfiles,'\')>0;

Else

Return False;

end if;

end;

/*

创建一个控制文件来重新加载卸载的数据。

*/

procedure dump_ctl(p_dir in varchar2,

p_filename in varchar2,

p_tname in varchar2,

p_mode in varchar2,

p_separator in varchar2,

p_enclosure in varchar2,

p_terminator in varchar2)

is

l_output  utl_file.file_type;

l_sep     varchar2(5);

l_str     varchar2(5) := chr(10);

begin

if (is_windows)

then

l_str := chr(13)||chr(10);

end if;

l_output := utl_file.fopen(p_dir,p_filename||'.ctl','w');

utl_file.put_line(l_output,'load data');

utl_file.put_line(l_output,'infile '''||

p_filename||'.dat'' "str x'''||

utl_raw.cast_to_raw(p_terminator||l_str)||'''"');

utl_file.put_line(l_output,'into table '|| p_tname);

Utl_File.Put_Line(L_Output,'fields terminated by X'''|| To_Hex(P_Separator)||''' enclosed by X '''||

to_hex(p_enclosure)||''' ');

utl_file.put_line(l_output,'(');

/*遍历表的desc*/

for i in 1 .. g_desctbl.count

loop

if (g_desctbl(i).col_type = 12)

then utl_file.put(l_output,l_sep||g_desctbl(i).col_name|| ' date ''ddmmyyyyhh24miss'' ');

Else

utl_file.put(l_output,l_sep||g_desctbl(i).col_name|| ' char('||to_char(g_desctbl(i).col_max_len*2)||')');

end if;

l_sep := ','||g_nl;

end loop;

utl_file.put_line(l_output,g_nl || ')');

utl_file.fclose(l_output);

end;

/*返回一个加引号的串。*/

function quote(p_str in varchar2,p_enclosure in varchar2)

return varchar2

is

begin

return p_enclosure || replace(p_str,p_enclosure,p_enclosure||p_enclosure)||p_enclosure;

end;

/*下面是主函数。*/

Function Run(P_Query In Varchar2,

p_tname in varchar2,

p_mode  in varchar2 default 'REPLACE',

p_dir   in varchar2,

p_filename in varchar2,

p_separator in varchar2 default ',',

p_enclosure in varchar2 default '"',

p_terminator in varchar2 default '|' ) return number

is

l_output utl_file.file_type;

l_columnValue varchar2(4000);

L_Colcnt Number Default 0;

l_separator varchar2(10) default  '';

l_cnt  number default 0;

l_line long;

l_datefmt varchar2(255);

l_descTbl dbms_sql.desc_tab;

begin

/*将NLS_DATE_FORMAT保存到一个变量中,从而在将数据转储到磁盘上时可以把它改为一种保留日期和时间的格式*/

select value

into l_datefmt

From Nls_Session_Parameters

where parameter = 'NLS_DATE_FORMAT';

execute immediate  'alter session  set nls_date_format = ''ddmmyyyyhh24miss''';

Begin

/*解析并描述这个查询。将G_DESCTBL 设置为L_DESTBL来重置全局表;否则,其中会包含前DESCRIBE生成的数据

而不只是当前查询生成的数据。一旦完成,再调用DUMP_CTL具体创建控制文件

*/

Dbms_Sql.Parse(G_Thecursor,P_Query,Dbms_Sql.Native);

g_descTbl := l_descTbl;

dbms_sql.describe_columns(g_theCursor,l_colCnt,g_descTbl );

/*

*/

dump_ctl(p_dir,p_filename,p_tname,p_mode,p_separator,p_enclosure,p_terminator);

/*

将每一个column绑定成一个varchar2(4000)。不用关心这个数是什么类型,每一个东西都可以变成string

现在可以具体数据转储到磁盘上。首先将每一个列定义为varchar2(4000)来获取数据。所有类型(number

date row)都要转换为 varchar2.

*/

For I In 1 .. L_Colcnt Loop

dbms_sql.define_column(g_theCursor,i,l_columnValue,4000);

end loop;

/*

现在打开数据文件准备些,从查询获取所有行,并将其打印到数据文件

*/

l_cnt := dbms_sql.execute(g_theCursor);

l_output := utl_file.fopen(p_dir,p_filename||'.dat','w',32760);

loop

exit when(dbms_sql.fetch_rows(g_theCursor) <= 0);

l_separator := '';

l_line := null;

for i in 1 ..  l_colCnt loop

dbms_sql.column_value(g_theCursor,i,l_columnValue);

l_line := l_line || l_separator ||

Quote(L_Columnvalue,P_Enclosure);

l_separator := p_separator;

end loop;

l_line := l_line || p_terminator;

utl_file.put_line(l_output,l_line);

l_cnt := l_cnt+1;

end loop;

utl_file.fclose(l_output);

/*将日期格式设置回原来的样子

*/

execute immediate'alter session set nls_date_format = ''' || l_datefmt|| '''';

return l_cnt;

exception

when others then

execute immediate

'alter session set nls_date_format = ''' || l_datefmt|| '''';

RAISE;

end;

end run;

end expfile;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle P/L SQL实现FTP上传、下载功能,以下是此过程包的头部,包体经常打包处理plb,感兴趣用户可以下载下来。 --Oracle上的FTP功能 Create or Replace Package UTL_FTP AUTHID CURRENT_USER as Type Connection is Record( Connection UTL_TCP.Connection, AccountInfo VarChar2(1000), TransferMethod Char(1), --A: ASCII, E: EBCDIC, I: IMAGE TransferOption Char(1), LocalDirectory VarChar2(30), LastReply VarChar2(32767 ) ); Type File_List is Table of VarChar2(32767) Index by Binary_Integer; is_FTPStatus VarChar2(800) := 'disconnect'; is_FTPPort Constant Integer := 21; is_TransferMethod Constant VarChar2(10) := 'ASCII'; ii_OutputLog Constant Integer := 1; ii_RollBufferLog Constant Integer := 2; ii_ClientInfoLog Constant Integer := 4; -- Per RFC 959, if account info ( ACCT ) is requested Then a 332 code -- should be Returned from the PASS command instead of a Positive Completion ii_FTPRequestAcct Constant Integer := 332; gb_Verbose Boolean := False; --是否记录冗长、累赘的日志 gi_LogOptions Integer := ii_OutputLog; gs_LogText VarChar2(32767) := Null; Procedure p_SetVerbose( ab_Verbose in Boolean ); Procedure p_SetLogOptions( ai_LogOptions in Integer ); Procedure p_ClearLog; --登录到远程FTP服务器 Function f_Login( as_RemoteHost in VarChar2, as_Username in VarChar2, as_Password in VarChar2, as_LocalDirectory in VarChar2 Default Null, as_RemoteDir in VarChar2 Default Null, as_TransferMethod in VarChar2 Default is_TransferMethod, ai_Timeout in Integer Default Null, ai_FTPPort in Integer Default is_FTPPort, as_AccountInfo in VarChar2 Default Null )Return Connection; Procedure p_Logout( ac_Connection in out Nocopy Connection ); Procedure p_SendFTPCmd( ac_Connection in out Nocopy Connection, as_Command in VarChar2, as_Argument in VarChar2 Default Null, as_AccountInfo in VarChar2 Default Null ); Procedure p_ReadReply( ac_Connection in out Nocopy Connection ); Procedure p_Rename( ac_Connection in out Nocopy Connection, as_OldFilename in VarChar2, as_NewFilename in VarChar2 ); Procedure p_DeleteFile( ac_Connection in out Nocopy Connection, as_Filename in VarChar2 ); Function f_isDirectory( ac_Connection in out Nocopy Connection, as_Directory in VarChar2, ab_CDToo in Boolean Default True )Return Boolean; Procedure p_CreateDirectory( ac_Connection in out Nocopy Connection, as_Directory in VarChar2 ); Procedure p_DeleteDirectory( ac_Connection in out Nocopy Connection, as_Directory in VarChar2 ); Procedure p_SetTransferMethod( ac_Connection in out Nocopy Connection, as_TransferMethod in VarChar2, as_Option in VarChar2 Default Null ); Procedure p_RemoteCD( ac_Connection in out Nocopy Connection, as_Directory in VarChar2, ab_CreateDir in Boolean Default True ); Procedure p_RemoteCDup( ac_Connection in out Nocopy Connection ); Function f_RemotePWD( ac_Connection in out Nocopy Connection )Return VarChar2; Procedure p_PutClob( ac_Connection in out Nocopy Connection, ac_LocalClob in Clob, as_RemoteFilename in VarChar2, as_TransferMethod in VarChar2 Default Null ); Function f_PutClob( ac_Connection in out Nocopy Connection, ac_LocalClob in Clob, as_RemoteFilename in VarChar2, as_TransferMethod in VarChar2 Default Null )Return VarChar2; Procedure p_PutBlob( ac_Connection in out Nocopy Connection, ab_LocalBlob in BLOB, as_RemoteFilename in VarChar2, ab_ForceBinary in Boolean Default True --强制为二进制 ); Procedure p_GetClob( ac_Connection in out Nocopy Connection, as_RemoteFilename in VarChar2, ac_LocalClob in out Nocopy Clob, as_TransferMethod in VarChar2 Default Null ); Function f_GetClob( ac_Connection in out Nocopy Connection, as_RemoteFilename in VarChar2, as_TransferMethod in VarChar2 Default Null )Return Clob; Procedure p_GetBlob( ac_Connection in out Nocopy Connection, as_RemoteFilename in VarChar2, ab_LocalBlob in out Nocopy BLOB, ab_ForceBinary in Boolean Default True ); Function f_GetBlob( ac_Connection in out Nocopy Connection, as_RemoteFilename in VarChar2, ab_ForceBinary in Boolean Default True )Return BLOB; Procedure p_PutFile( ac_Connection in out Nocopy Connection, ai_LocalFilename in UTL_File.File_Type, as_RemoteFilename in VarChar2, as_TransferMethod in VarChar2 Default Null ); Procedure p_PutFile( ac_Connection in out Nocopy Connection, as_LocalDirectory in VarChar2, as_LocalFilename in VarChar2, as_RemoteFilename in VarChar2, as_TransferMethod in VarChar2 Default Null ); Function f_PutFile( ac_Connection in out Nocopy Connection, as_LocalDirectory in VarChar2, as_LocalFilename in VarChar2, as_RemoteFilename in VarChar2, as_TransferMethod in VarChar2 Default Null )Return VarChar2; Procedure p_PutFile( ac_Connection in out Nocopy Connection, as_LocalDirectory in VarChar2, as_LocalFilename in VarChar2 ); Procedure p_GetFile( ac_Connection in out Nocopy Connection, as_RemoteFilename in VarChar2, as_LocalDirectory in VarChar2, as_LocalFilename in VarChar2, as_TransferMethod in VarChar2 Default Null ); Procedure p_GetFile( ac_Connection in out Nocopy Connection, as_RemoteFilename in VarChar2, as_TransferMethod in VarChar2 Default Null ); Procedure p_GetFile( ac_Connection in out Nocopy Connection, as_RemoteFilename in VarChar2, ai_LocalFilename in out Nocopy UTL_File.File_Type, as_TransferMethod in VarChar2 Default Null ); Procedure p_GetFileList( ac_Connection in out Nocopy Connection, afl_List out File_List, as_RemotePath in VarChar2 Default Null, ab_FilenameOnly in Boolean Default True, as_FilenamePrefix in VarChar2 Default Null, as_FilenameExt in VarChar2 Default Null, as_TransferMethod in VarChar2 Default is_TransferMethod ); Function f_GetFileList( ac_Connection in out Nocopy Connection, as_RemotePath in VarChar2 Default Null, ab_FilenameOnly in Boolean Default True, as_FilenamePrefix in VarChar2 Default Null, as_FilenameExt in VarChar2 Default Null, as_TransferMethod in VarChar2 Default is_TransferMethod )Return File_List; --根据FTP参数或系统事先设定好的IP登录到FTP服务器 --Select UTL_FTP.f_ConnectFTP() From dual; Function f_ConnectFTP( as_RemoteSubDir in VarChar2 Default Null, --Remote Subdirectory as_RemoteFileWildcard in VarChar2 Default Null, --Remote File Wildcard --删除之前生成的文件 如I02-UB*.xls as_FTPServer in VarChar2, --FTP Server as_FTPUserID in VarChar2, --FTP User ID as_FTPPasswd in VarChar2 --FTP Password )Return UTL_FTP.Connection; END UTL_FTP; /
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值