mysqldump备份、还原数据库路径名含有空格的处理方法(如:Program Files)

虽然以下的方法也可以解决,不过最简单直接的,还是直接在路径前后加双引号-" ",这个方法简单有效。

首先要说明的是mysqldump.exe在哪里不重要,重要的是要处理好路径中的非法字符。

比如:我的mysqldump.exe的位置在本地的

C:\Program Files\Apache Software Foundation\Tomcat 6.0\webapps\ui\WEB-INF\data\test

直接调用肯定是不行的,因为路径中有空格。
解决方法是把空格换成

C:/Progra~1/Apache~1/Tomcat~1.0/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~1/Apache~1/Tomcat~1.0/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.

---------------------------------------------------------------------------------------------------------

GetShortPathName 得到长文件名对应的8.3格式的短文件名

当Windows进入长文件名时代,因此dos时代的8.3格式文件命就派不上用了, 但是有些时候8.3格式文件名却很有用,例如当一个word的文件名有空格时,要用shell的方式打开word文件时,word就把文件名当中的空格截掉,导致文件打开会失败,解決方法就是用GetShortPathName讲长文件名转换为短文件名。

例如:

GetShortPathName (L"C:\\Documents and Settings\\All Users", szOut,  sizeof(szOut));

返回C:\DOCUME~1\ALLUSE~1

具体说明在:http://technet.microsoft.com/en-us/library/cc959352.aspx

时间: 2024-10-12 08:14:20

mysqldump备份、还原数据库路径名含有空格的处理方法(如:Program Files)的相关文章

SQL点滴12—SQL Server备份还原数据库中的小把戏

原文:SQL点滴12-SQL Server备份还原数据库中的小把戏 备份数据库时出现一个不太了解的错误 ,错误信息“is formatted to support  1 media families, but 2 media families are expected according to the backup device specification”.如下图: 解决办法是首先选中击上一次备份的文件,点击Remove,去掉当前的备份文件,然后再点击OK备份.这样才能正确的备份.也在微软帮助

使用mysqldump备份mysql数据库

1.权限授予一览表 权限 权限限定语句 说明 授予语句 Show_db_priv 用户只可以用show databases语句 查看数据库名 SHOW DATABASES Select_priv 用户可以使用show语句.use语句.desc语句.select语句 只读权限,除了不可以修改.增加和删除,可以获取一切数据 SELECT Insert_priv 用户可以使用show语句.use语句.insert语句 可以看到数据库名.表名,向表中增加数据 INSERT Update_priv 用户可

【摘】Mysql备份还原数据库之mysqldump实例及参数详细说明

原文http://www.cnblogs.com/xuejie/archive/2013/01/11/2856911.html   我们在运营项目的过程中肯定会遇到备份数据库,还原数据库的情况,我们一般用一下两种方式来处理: 1.使用into outfile 和 load data infile导入导出备份数据 这种方法的好处是,导出的数据可以自己规定格式,并且导出的是纯数据,不存在建表信息,你可以直接导入另外一个同数据库的不同表中,相对于mysqldump比较灵活机动. 我们来看下面的例子:

Mysql备份还原数据库之mysqldump实例及参数详细说明

http://www.xuejiehome.com/blfl-2.html http://www.cnblogs.com/xuejie/archive/2013/01/11/2856911.html 我们在运营项目的过程中肯定会遇到备份数据库,还原数据库的情况,我们一般用一下两种方式来处理: 1.使用into outfile 和 load data infile导入导出备份数据 这种方法的好处是,导出的数据可以自己规定格式,并且导出的是纯数据,不存在建表信息,你可以直接导入另外一个同数据库的不同

mysql备份还原数据库

1.备份数据库 mysqldump -u root -p test>/home/victor/test.sql 说明:如果提示找不到mysqldump命令,先用一条find命令查找mysqldump的所在路径 find / -name mysqldump -print 然后再用ln命令链接到/usr/bin下面 ln -fs /opt/lampp/bin/mysqldump /usr/bin 2.还原数据库 mysql; #切换到数据库模式 use test;#进入数据库(先用Navicat创建

mysqldump备份还原mysql

本文实现在mysql 5.7 解压版为例子 1.在window上简单试下一个例子 1.使用管理员权限打开cmd命名行,并切换到mysqldump执行程序下 2.以改数据库为例子,在导出路径下先建立空文件,否则报错找不到文件 3.执行命令 mysqldump -u root -p grc_order > D:\mysql-bak\order.sql 提示输入密码,输入后确定,完成 4.发现sql文件大小变了,备份成功 打开开开发现有完整的建表,插入数据,lock语句 5.还原,闲创建数据库,执行以

从零开始——Mysql备份还原数据库

 1.使用phpmysql导入导出 特点:方便但是有限制 2. 使用into outfile 和 load data infile导入导出备份数据 这种方法的好处是,导出的数据可以自己规定格式,并且导出的是纯数据,不存在建表信息,你可以直接导入另外一个同数据库的不同表中,相对于mysqldump比较灵活机动. 我们来看下面的例子: (1)下面的mysql命令是把select的mytable表中的数据导出到/home/db_bak2012文件. select * from mytable wher

分析VTL以及利用日志备份还原数据库到指定时间

本文原整理于2012-09 一备份链 USEMASTER; GO CREATEDATABASElogtest 运行如下语句 USElogtest go DBCCloginfo 图1-1 运行如下语句可以看到产生很多VTL USElogtest go SELECTTOP 10000 *INTOt1 FROMAdventureWorks.Sales.SalesOrderHeader DBCCloginfo 图1-2 运行如下语句可以看到日志被截断,标记为可重用状态(status=0) USElogt

sqlserver备份还原数据库时报占用错误

1.做项目时遇到这种情形:原来的test_dev数据库,想复制出test_ft供测试用.此时备份test_dev出test_backup文件,想直接还原成test_ft时会报占用错误. 还原数据库:The backup set holds a backup of a database other than the existing database 因为数据库正在使用,所以无法获得对数据库的独占访问权 2.原因:(1)备份文件里面保存着原有数据库及文件名称信息,默认会还原成test_dev数据库