• 在Win8中用批处理创建Oracle数据库时报“Unable to open file”


    这一问题的原因是在运行批处理时使用了“以管理员权限运行”。如果直接双击运行是没有问题的。

    如果我就想用管理员权限运行呢?

    出这个错误的原因是,以管理员权限运行时的当前目录不是批处理所在的目录了。所以,解决的方法也简单。只要在批处理的开头加上下面这句就可以了。

    cd /d %~dp0
    

    这句话是什么意思呢?

    %~dp0 “d”为Drive的缩写,即为驱动器,磁盘、“p”为Path缩写,即为路径,目录
    cd是转到这个目录,不过我觉得cd /d %~dp0 还好些
    
    选项语法:
    
        ~0         - 删除任何引号("),扩充 %0
        %~f0        - 将 %0 扩充到一个完全合格的路径名(“f”是file,即文件)
        %~d0        - 仅将 %0 扩充到一个驱动器号
        %~p0        - 仅将 %0 扩充到一个路径
        %~n0        - 仅将 %0 扩充到一个文件名(“n”是name 文件名)
        %~x0        - 仅将 %0 扩充到一个文件扩展名
        %~s0        - 扩充的路径只含有短名(“s”为Short,短的)
        %~a0        - 将 %0 扩充到文件的文件属性(“a”为attribute,即属性)
        %~t0        - 将 %0 扩充到文件的日期/时间(“t”time)
        %~z0        - 将 %0 扩充到文件的大小(Size 大小)
        %~$PATH:0   - 查找列在路径环境变量的目录,并将 %0 扩充
                      到找到的第一个完全合格的名称。如果环境变量名
                      未被定义,或者没有找到文件,此组合键会扩充到
                      空字符串
    
    可以组合修饰符来得到多重结果:
    
        %~dp0       - 仅将 %0 扩充到一个驱动器号和路径
        %~nx0       - 仅将 %0 扩充到一个文件名和扩展名
        %~fs0       - 仅将 %0 扩充到一个带有短名的完整路径名
        %~dp$PATH:0 - 查找列在路径环境变量的目录,并将 %I 扩充
                      到找到的第一个驱动器号和路径。
        %~ftza0     - 将 %0 扩充到类似输出线路的 DIR
    
    %0为当前批处理文件
    如果0换成1为第一个文件,2为第2个
    

      

  • 相关阅读:
    自定义注解!绝对是程序员装逼的利器!!
    mybatis连接数据库错误解决方法
    SQL基础
    【2021-1-5】QT+SQLsever数据库的数据管理系统
    以友盟+U-Push为例,深度解读消息推送的筛选架构解决方案应用与实践
    基于Linux的MySQL基本操作
    SQL server函数转Oracle问题之一,强行使用临时表
    安装 部署 postgresql数据库 搭建主从节点 (业务库)
    SQL练习题一(逐行累计)
    ThinkPHP中,display和assign用法详解
  • 原文地址:https://www.cnblogs.com/Aricc/p/4184255.html
Copyright © 2020-2023  润新知