转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 数据库 >> ORACLE >> 正文
如何使用Oracle的BFILE         ★★★★

如何使用Oracle的BFILE

作者:闵涛 文章来源:闵涛的学习笔记 点击数:1444 更新时间:2009/4/22 22:04:18


如何使用Oracle的BFILE
1.创建相应的directory
使用具有足够权限的用处创建directory,具体参考:Using Create directory & UTL_FILE in Oracle
create or replace directory BFILE_DIR as
''''/home/oracle/bfiletest'''';

[oracle@ts01 bfiletest]$ sqlplus ''''/ as sysdba''''

SQL*Plus: Release 9.2.0.6.0 - Production on Mon Jan 23 10:54:17 2006

Copyright (c) 1982, 2002, Oracle Corporation.  All rights reserved.


Connected to:
Oracle9i Enterprise Edition Release 9.2.0.6.0 - Production
With the Partitioning, OLAP and Oracle Data Mining options
JServer Release 9.2.0.6.0 - Production

SQL> show parameter utl_file_dir   ***************9.2开始,已经废弃了这个参数

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
utl_file_dir                         string
SQL>
SQL> create or replace directory BFILE_DIR as
  2  ''''/home/oracle/bfiletest'''';

Directory created.

Elapsed: 00:00:00.05
SQL>
SQL> col DIRECTORY_PATH for a50
SQL> select * from dba_directories;

OWNER                          DIRECTORY_NAME                 DIRECTORY_PATH
------------------------------ ------------------------------ --------------------------------------------------
SYS                            MEDIA_DIR                      /oracle/product/920/demo/schema/product_media/
SYS                            LOG_FILE_DIR                   /oracle/admin/TSMISC02/create/
SYS                            DATA_FILE_DIR                  /oracle/product/920/demo/schema/sales_history/
SYS                            KU$_STYLESHEET_DIR             /oracle/product/920/rdbms/xml/xsl
SYS                            BFILE_DIR                      /home/oracle/bfiletest

Elapsed: 00:00:00.01
SQL>

 

2.给相应的用户授权
grant read on directory BFILE_DIR  to lunar;

SQL> grant read on directory BFILE_DIR  to lunar;

Grant succeeded.

Elapsed: 00:00:00.04
SQL>
 

3.检查相应的文件是否存在
host ls -l /home/oracle/bfiletest/bfiletest_file.txt

SQL> host ls -l /home/oracle/bfiletest/bfiletest_file.txt
-rw-r--r--    1 root     root          349 Oct 31  2003 /home/oracle/bfiletest/bfiletest_file.txt

SQL>
 

4.数据操作
BFILENAME函数的语法如下:BFILENAME(''''directory'''',''''filename'''')
该函数用以返回一个BFILE文件位置指针,指针和文件系统上的LOB binary文件相关联。
''''directory'''' 是路径名,通过create directory方式创建。 ''''filename'''' 是文件系统上的文件名称
在你在SQL,PL/SQL或者DBMS_LOG包,或者OCI中使用BFILENAME函数之前,你必须创建相应的directory并且关联相应的物理文件.
以下是一个示例:
  CREATE DIRECTORY media_dir AS ''''/demo/schema/product_media'''';
  create table lunar_test (product_id number, ad_id number, ad_graphic bfile );
  INSERT INTO print_media (product_id, ad_id, ad_graphic)
     VALUES (3000, 31001, bfilename(''''MEDIA_DIR'''', ''''modem_comp_ad.gif''''));
  参考:Oracle9i SQL Reference Release (9.2) Part Number A96540-02

再例如:
  SQL> connect lunar/lunar
  create table lunar_test (id number, bfiles bfile );
  
  insert into lunar_test values ( 1, bfilename ( ''''BFILE_DIR'''', ''''bfiletest_file.txt'''' ) );
  
  SQL> connect lunar/lunar
  Connected.
  SQL> create table lunar_test (id number, bfiles bfile );
  
  Table created.
  
  Elapsed: 00:00:00.03
  SQL> insert into lunar_test values ( 1, bfilename ( ''''BFILE_DIR'''', ''''bfiletest_file.txt'''' ) );
  
  1 row created.
  
  Elapsed: 00:00:00.00
  SQL> commit;
  
  Commit complete.
  
  Elapsed: 00:00:00.00
  SQL>

 

declare                                                                           
  fhandle utl_file.file_type;                                                     
begin                                                                             
  fhandle := utl_file.fopen(''''BFILE_DIR'''', ''''lunartest1.txt'''', ''''w'''');                  
  utl_file.put_line(fhandle , ''''aaa'''');                            
  utl_file.put_line(fhandle , ''''bbb'''');                            
  utl_file.fclose(fhandle);                                                       
end;                                                                              
/                                                                                 


declare                                                                       
  fhandle   utl_file.file_type;                                               
  fp_buffer varchar2(

[1] [2]  下一页


[平面设计]如何使用FireWorks制作沿路径排列的文字效果  [网络技术]如何使用DOS命令有计划地重新启动IIS
[电脑技术]图文解说如何使用QQ截图  [系统软件]如何使用WinMe的系统还原功能
[系统软件]如何使用Ghost备份和恢复系统  [VB.NET程序]如何使用 VB 编写自动反安装的程序?
[网页制作]如何使用Microsoft FrontPage 2000制作动态按钮  [Web开发]如何使用ajax开发web应用程序(三)
[Web开发]如何使用ajax开发web应用程序(二)  [Web开发]如何使用ajax开发web应用程序(一)
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · Sql Server  · MySql
    · Access  · ORACLE
    · SyBase  · 其他
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台