ホームページ > データベース > mysql チュートリアル > pl/sql传入路径和文件以及操作系统 获得相应的文件完整路径

pl/sql传入路径和文件以及操作系统 获得相应的文件完整路径

WBOY
リリース: 2016-06-07 14:55:03
オリジナル
1202 人が閲覧しました

主要就是针对不同的操作系统,才必须要注意这个情况,对于在数据库中保存相应的文件路径有很大的作用 PL/SQL 文件路径 --获得解析文件路径 :传入路径,文件名,操作系统标识 w,ufunction resolve_filename (p_dir in varchar2, p_file_name in varchar2, p_o

主要就是针对不同的操作系统,才必须要注意这个情况,对于在数据库中保存相应的文件路径有很大的作用 PL/SQL 文件路径
--获得解析文件路径 :传入路径,文件名,操作系统标识 w,u
function resolve_filename (p_dir in varchar2,
                           p_file_name in varchar2,
                           p_os in varchar2 := g_os_windows) return varchar2
as
  l_returnvalue t_file_name;
begin

  /*

  Purpose:      resolve filename, ie. properly concatenate dir and filename

  Remarks:

  Who     Date        Description
  ------  ----------  --------------------------------
  MBR     01.01.2005  Created

  */
  --如果是 是 windows
  if lower(p_os) = g_os_windows then
    --如果最后一位字符时 \
    if substr(p_dir,-1) = g_dir_sep_win then
      --设定返回值为 路径+文件名称
      l_returnvalue:=p_dir || p_file_name;
    else
      --如果没有 \ 则自己加一个上去
      if p_dir is not null then
        l_returnvalue:=p_dir || g_dir_sep_win || p_file_name;
      else
        l_returnvalue:=p_file_name;
      end if;
    end if;
  --如果是unix 就为 / 思路和上面一致
  elsif lower(p_os) = g_os_unix then

    if substr(p_dir,-1) = g_dir_sep_unix then
      l_returnvalue:=p_dir || p_file_name;
    else
      if p_dir is not null then
        l_returnvalue:=p_dir || g_dir_sep_unix || p_file_name;
      else
        l_returnvalue:=p_file_name;
      end if;
    end if;
  --如果都不是 就无返回值
  else
    l_returnvalue:=null;
  end if;

  return l_returnvalue;

END resolve_filename;
ログイン後にコピー
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート