今天写一个功能发现写入数据库的文件路径全被转换了把"\"都没了,如:“C:UsersAdministratorDesktop est1.txt”,本来该路径应该为“C:\Users\Administrator\Desktop\test\1.txt”,发现是进行了斜杠的转义,但是添加断点监控写入的sql为“C:\\Users\\Administrator\\Desktop\\test\\1.txt”,应该没问题,通过手动将该sql拷贝到navicat中执行,写入数据库格式也是正确的。然后就试了下将路径的字段进行了以下方法的转换
string GetDbTypePath(string strPath)
{
if (!string.IsNullOrEmpty(strPath))
{
return strPath.Replace("\\","\\\\");
}
return string.Empty;
}
再次执行,写入数据库格式正确。
使用的数据库为MYSQL,其他数据库不知道是否也有该情况,未进行测试。
回头看这个问题就很明显了,当我们通过程序执行sql语句时,其实在数据库中执行的是“C:\Users\Administrator\Desktop\test\1.txt”,数据库自然会对其进行转换,所以要手动进行转换。
时间: 2024-10-12 20:49:17