mysqldump备份、还原数据库路径名含有空格的处理方法(如:Program Files)
虽然以下的方法也可以解决,不过最简单直接的,还是直接在路径前后加双引号-" ",这个方法简单有效。
首先要说明的是mysqldump.exe在哪里不重要,重要的是要处理好路径中的非法字符。
比如:我的mysqldump.exe的位置在本地的
C:\Program Files\Apache Software Foundation\Tomcat .\webapps\ui\WEB-INF\data\test
直接调用肯定是不行的,因为路径中有空格。
解决方法是把空格换成
C:/Progra~/Apache~/Tomcat~./webapps/ui/WEB-INF/data/mau
的样子。
这里分两种情况:
1、Program Files、Apache Software Foundation
类似这种的直接保留前六个字母,再加“~1”就行了
2、Tomcat 6.0 、tomcattomcat 6.0、tom 6.0、to 6.0
这个需要保留“.0”,最终换成Tomcat~1.0 、Tomcat~1.0 、tom6~1.0、to6~1.0
规律一看都能看明白。
最终处理结果如下:
C:/Progra~/Apache~/Tomcat~./webapps/ui/WEB-INF/data/test/mysqldump.exe ...
其实以上就是所谓的DOS 8.3格式文件名规范。
所谓8.3格式短文件名规范,就是型如 PROGRA~1(目录)或者元素周~1.exe(文件)这样的名称——
“8”是指文件名或目录名的主体部分小于等于8个字节;
“3”是指文件名的扩展名部分小于等于3个字节。
另外还有一点,就是8.3文件名的有效字符不包括空格等特殊字符。
8.3短文件名格式规范是DOS+FAT12/FAT16时代遗留下的老规矩,自从Windows95开始(其实据说从Windows for Groups 3.11开始),Windows就已经能支持长文件名,但是为了向前兼容,特别是文件系统兼容性,FAT文件系统均强制执行“为长文件名提供8.3兼容格式的短文件名”的特性。
因此你会看到,在FAT16/32文件系统上:目录"program files"同时还拥有一个8.3规范的"PROGRA~1"短名称;而文件"元素周期表.exe"也同时拥有一个"元素周~1.exe"的短名称。[这有一点像类UNIX系统下的hardlink,一个对象拥有两个引用方式。]
PS:知道为什么IE浏览器的主程序叫做iexplore.exe 而不是iexplorer么?就是为了照顾8.3短文件名规范。
===================NTFS文件系统与8.3格式规范的兼容性===================
NTFS文件系统支持unicode(UTF16)字符集文件名,最长达255个UTF16字符,因此NTFS文件系统以及基于unicode字符集的32位NT内核Windows操作系统本身都没有必要遵循16位DOS时代遗留的8.3格式短文件名规范。
但还是为了兼容性,NTFS文件系统也提供了一个可选的特性:8.3兼容格式。Windows中这个特性默认是on,也就是说每当建立一个长文件名的对象的同时,系统的NTFS驱动模块会自动建立一个合适的8.3格式短名称指向这个对象。
需要指出的是,这个特性并不像FAT文件系统中那样是强制执行的,因此不同的磁盘实用程序或者操作系统可能有不同的执行方式——
比如windowsXP中可以用 fsutil behavior set disable8dot3 1 命令关闭,驱动模块关闭这一特性后就不会每次都额外地建立一个附加的短名称,这样在新建/重命名大量小文件/目录的时候能略微提升磁盘的写入速度,(不用计算出一个合适的短文件名,也不用把这个额外的信息写入磁盘)。
=================非win32标准的老程序兼容性依赖8.3规范=================
但是,关闭这一特性之后可能导致某些古老的应用程序出现兼容性问题,这些程序虽说是32位GUI界面的“windows应用程序”,却不完全遵循win32程序的规范,而是通常混合有16位API,使用8.3格式短名称来引用文件。很显然,如果在一个NTFS分区上根本就不为长文件名提供短名称,那么这些16/32位混合型老程序将无法用8.3格式短名称来找到文件,当然会出错……但是事情并不总是这么简单的——
最近我发现有几个老的应用程序不能正常启动,这包括曾经在科大校园网上非常流行的科技大词典(主程序 ncce_win.exe,怎么样,熟悉不?)细查原因,似乎只是放在NTFS分区才会出问题,移到FAT32的U盘上没问题。后来我惊讶的发现:把U盘格成NTFS再放上这个程序也没问题!…… ……
数小时后,真正的的原因被找到了,说起来非常复杂,简而言之:全路径上有一级目录不兼容短文件名格式,因此主程序找不到相关文件!
为什么会有一级目录不兼容8.3规范呢?
因为我的硬盘是在以前的硬盘出故障后新换的,换上来之前,我在一个64位windows操作系统上把旧硬盘上还能读出的目录一一复制过来,而那个64位windows关闭了NTFS的8.3兼容特性,复制来的目录和文件都不具备附加的短名称,特别是我放应用程序的E:\program files\目录。(64位windows理论上是完全不支持16位和16/32位混合程序的,因此可能默认就关闭了NTFS驱动的8.3兼容性,或者也许是什么优化程序关闭的。)
然后我用GHOST恢复了系统分区,恢复的32位winXP并没有关闭8.3兼容性,但关键问题是已经写入NTFS分区的(不具备短名称的)目录和文件并不会被这个32位XP重建短文件名,系统只会对新建的文件或目录附加8.3文件名,至于原先已经建立好的目录和文件,即使是重命名这种操作,也无法“提醒”XP检查并追加上一个短文件名——这一点让我百思不得其解。
于是,当我把软件放在E:\program files\的子目录中时,虽然子目录“科技词典”,以及ncce_win.exe等文件名都符合8.3规范,但是全路径上有一个“program files”是不符合8.3规范的,并且没有等效的短名称代替,所以某个API就无法用“E:\progra~1\科技词典\xxxxxxxx.xxx”定位文件了,这个程序当然无法正常启动。
-----------------------与8.3兼容名称相关的一些命令-----------------------
fsutil behavior query disable8dot3 检查NTFS驱动是否开启8.3兼容特性
fsutil behavior set disable8dot3 1 关闭8.3兼容特性
fsutil behavior set disable8dot3 0 开启8.3兼容特性
fsutil file setshortname <longname> <8.3name> 手工指定一个8.3短名称
dir /x 列出当前目录的子目录和文件,以及相应的8.3兼容名称(如果有的话)
---------------------------------------------------------------------------------------------------------
Windows 关闭、开启短文件名功能:
打开注册表,找到:HKLM\SYSTEM\CurrentControlSet\Control\FileSystem
将 NtfsDisable8dot3NameCreation 的值设为 1,也就是不创建短文件名,具体含义如下:
0 NTFS creates short file names. This setting enables applications that cannot process long file names and computers that use different code pages to find the files.
1 NTFS does not create short file names. Although this setting increases file performance, applications that cannot process long file names and computers that use different code pages might not be able to find the files.
---------------------------------------------------------------------------------------------------------
具体说明在:http://technet.microsoft.com/en-us/library/cc959352.aspx
mysqldump备份、还原数据库路径名含有空格的处理方法(如:Program Files)的更多相关文章
- [转]mysqldump备份还原和mysqldump导入导出语句大全详解
FROM : http://www.cnblogs.com/zeroone/archive/2010/05/11/1732834.html mysqldump备份还原和mysqldump导入导出语句大 ...
- SQL点滴12—SQL Server备份还原数据库中的小把戏
原文:SQL点滴12-SQL Server备份还原数据库中的小把戏 备份数据库时出现一个不太了解的错误 ,错误信息“is formatted to support 1 media families, ...
- 如何使用T-SQL备份还原数据库及c#如何调用执行? C#中索引器的作用和实现。 jquery控制元素的隐藏和显示的几种方法。 localStorage、sessionStorage用法总结 在AspNetCore中扩展Log系列 - 介绍开源类库的使用(一) span<T>之高性能字符串操作实测
如何使用T-SQL备份还原数据库及c#如何调用执行? 准备材料:Microsoft SQL Server一部.需要还原的bak文件一只 一.备份 数据库备份语句:user master backup ...
- SQL 数据库 学习 005 学习必备的一些操作 --- 如何新建数据库 如何附加和分离数据库(如何备份还原数据库) 如何删除数据库
我的电脑系统: Windows 10 64位 使用的SQL Server软件: SQL Server 2014 Express 如果我们要学习这个数据库,我们需要学习什么知识.比如:如何新建一个数据库 ...
- WinForm c# 备份 还原 数据库(Yc那些事儿 转)
Yc那些事儿 我愿意 为了我的幸福 奋斗终生 2008-11-17 18:04 WinForm c# 备份 还原 数据库 其实是个非常简单的问题,一个Form,一个Button,一个OpenF ...
- 【摘】Mysql备份还原数据库之mysqldump实例及参数详细说明
原文http://www.cnblogs.com/xuejie/archive/2013/01/11/2856911.html 我们在运营项目的过程中肯定会遇到备份数据库,还原数据库的情况,我们一 ...
- Mysql备份还原数据库之mysqldump实例及参数详细说明
[root@localhost myexport]# mysqldump -h211.100.75.204 -uroot -p@^#coopen -P5029 --single-transaction ...
- (转)Mysql备份还原数据库之mysqldump实例及参数详细说明
http://www.xuejiehome.com/blfl-2.html http://www.cnblogs.com/xuejie/archive/2013/01/11/2856911.html ...
- Using mysqldump for Backups(备份还原数据库实例及参数详细说明)
官网mysqldump命令如下: Using mysqldump for Backups https://dev.mysql.com/doc/refman/5.7/en/using-mysqldump ...
随机推荐
- Unity 物体围绕圆周运动
用Unity开发游戏中,经常会有搜寻的功能,这时候我们需要一个放大镜的图标在那圆周运动.写了相关脚本直接挂载在要圆周运动的物体上即可: using UnityEngine; using System. ...
- HDwiki文件上传导致远程代码执行漏洞
漏洞版本: HDwiki(2011) 漏洞描述: 互动维客开源系统(HDwiki)作为中国第一家拥有自主知识产权的中文维基(Wiki)系统,由互动在线(北京)科技有限公司于2006 年11月28日正式 ...
- 【转】Android--多线程之Handler--不错
原文网址:http://www.cnblogs.com/plokmju/p/android_handler.html 前言 Android的消息传递机制是另外一种形式的“事件处理”,这种机制主要是为了 ...
- HUD --- 3635
Five hundred years later, the number of dragon balls will increase unexpectedly, so it's too difficu ...
- Unity3d 游戏中的实时降噪-对Square Enix文档的研究与实现
看到SE的技术文档关于降噪的决定研究一下,本次试验场景: 文章中提到了3中主要滤波方法,最后一种方法又有三种方式分别为Conventional geometry-aware filtering,Dist ...
- 【索引】Objective-C基础教程-读书笔记
第1章 启程 http://www.cnblogs.com/duxiuxing/p/5492219.html 第2章 对C的扩展 第3章 面向对象编程的基础知识 第4章 继承 第5章 复合 第6章 ...
- Java获取当前路径
1.利用System.getProperty()函数获取当前路径:System.out.println(System.getProperty("user.dir"));//user ...
- hdu 4717 The Moving Points(三分+计算几何)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4717 说明下为啥满足三分: 设y=f(x) (x>0)表示任意两个点的距离随时间x的增长,距离y ...
- 爬虫技术浅析 | WooYun知识库
爬虫技术浅析 | WooYun知识库 爬虫技术浅析 好房通ERP | 房产中介软件最高水准领导者 undefined
- HBase 简介(强烈推荐看)
本博文的主要内容有: .HBase定义 .HBase 的特点 .HBase 访问接口 .HBase 存储结构 .HBase设计 .HBase安装 .HBase shell操作 .输入 help 可 ...