日期:2014-05-16  浏览次数:20747 次

Mysql的字符/转义问题
小弟的linux服务器上装有mysql,远程连接数据库使用语句
select   *   from   admin   into   outfile   '/home/wwwroot/pages/ads/1.txt ';

提示出错:   Can 't   create/write   to   file   '/home/wwwroot/pages/ads/1.txt '   (Errcode:   2)
好像无法转义/字符,\可以用\\转义的,但是/怎么转义啊,这个\/好像不行哦

------解决方案--------------------
/是不用转义的,看看目录是否存在,mysql是不会建目录的.
------解决方案--------------------
参考一下:

A.2.12. 无法创建文件/写入文件
如果对某些查询遇到下述类型的错误,它意味着MySQL不能为临时目录下的结果集创建临时文件:

无法创建/写入文件 '\\sqla3fe_0.ism '。
前述错误是Windows平台上的典型消息,Unix平台上的消息与之类似。

一种更正方式是使用“--tmpdir”选项启动mysqld,或在选项文件的[mysqld]部分增加该选项。例如,要想指定目录C:\temp,可使用:

[mysqld]
tmpdir=C:/temp
目录C:\temp必须存在,并有足够的空间允许MySQL写入它。请参见4.3.2节,“使用选项文件”。

该错误的另一个原因可能是许可事宜。请确认MySQL服务器能够写入tmpdir目录。

此外,还用使用perror检查错误代码。服务器无法写入表的一个原因是文件系统已满。

shell> perror 28
错误代码28:磁盘上无剩余空间。