数据库写入文件路径

  今天写一个功能发现写入数据库的文件路径全被转换了把"\"都没了,如:“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

数据库写入文件路径的相关文章

c# mysql 字段写入文件路径异常问题

c# mysql 写入文件路径信息 ,mysql中"\"是转义字符,所以写入数据中 文件路径 d:\123\123.txt  就会变成d:123123.txt 在c#"\"也是转义字符 所以我们定义一个路径 string str = "d:\\123\\123.txt";  要保证写入mysql正常就需要将str变成 str="d:\\\\123\\\\123.txt"; 我们可以采用 str = str.replace(&q

创建SQL数据库指定文件路径

create database b2c on  primary  -- 默认就属于primary文件组,可省略(/*--数据文件的具体描述--*/    name='b2c',  -- 主数据文件的逻辑名称    filename='D:\Data\b2c.mdf', -- 主数据文件的物理名称    size=5mb, --主数据文件的初始大小    maxsize=100mb, -- 主数据文件增长的最大值    filegrowth=15%--主数据文件的增长率)log on(/*--日志

Android文件存储往SD卡中写入文件路径出错问题求解。

============问题描述============   因为学习需要  看的老罗的视频  关于数据存储往SD卡写文件的那一部分  几乎完全照办的敲的代码   结果在pad上测试的时候和预想的有区别     本来应该存储到SD卡中的文件结果跑到pad自带内存中去了...   然后我尝试过把路径直接自己手动写  还是一样存到了自带内存中  这到底是为什么啊? 顺带吐槽一下万恶的导师  十一还要我们加班 求大神们指导呀~   国庆节玩的开学哟!!! ============解决方案1======

C# 文件与二进制互转数据库写入读出

//这个方法是浏览文件对象 private void button1_Click(object sender, EventArgs e) { //用户打开文件浏览 using (OpenFileDialog dialog = new OpenFileDialog()) { //只能单选一个文件 dialog.Multiselect = false; //选择一个文件 if (dialog.ShowDialog() == DialogResult.OK) { try { //把选择的文件路径给tx

log4net.config 将日记同时写入到数据库和文件当中

<1> 1>在项目中新建新建一个log4net.config的配置文件. 2>从log4net官网下面log4net的文件包,然后在包的bin文件夹下的net文件夹中的4.0文件夹中找到log4net.dll文件,然后将它引入到我们的项目中来 <?xml version="1.0" encoding="utf-8"?> <configuration> <configSections> <!--配置一个

js上传文件带参数,并且,返回给前台文件路径,解析上传的xml文件,存储到数据库中

ajaxfileupload.js jQuery.extend({ createUploadIframe: function(id, uri) { //create frame var frameId = 'jUploadFrame' + id; if(window.ActiveXObject) { var io = document.createElement('<iframe id="' + frameId + '" name="' + frameId + '&qu

SQL2012还原数据库操作在本地服务器上操作和用别的电脑远程连接到服务器进行操作的文件路径差异

在数据库服务器上想还原一个数据库到某个备份文件时期的,服务器的数据库文件本身是保存在 D:\DEVDB目录 通过开发电脑上的MS manager来连接数据库服务器操作还原 虽发现文件卡项上,原始文件名与"还原为"的文件路径有所不同, 但由于想着是选了"覆盖现有数据库"方式进行还原,像以前操作sql2000一样,以为还原后的数据库会自动替换原文件 结果还原成功后,发现D:\DEVDB目录下的数据库文件已经不见了,而是被移到了C:\Program Files\Micro

Struts2 S2-016/S2-017 命令执行带回显、写入文件,看web路径、getshell exp整理

带回显命令执行: http://www.example.com/struts2-blank/example/X.action?redirect:${%23a%3d(new java.lang.ProcessBuilder(new java.lang.String[]{'cat','/etc/passwd'})).start(),%23b%3d%23a.getInputStream(),%23c%3dnew java.io.InputStreamReader(%23b),%23d%3dnew ja

Oracle数据库文件路径变更

环境:RHEL 6.4 + Oracle 11.2.0.3 情景一:只是部分普通数据文件迁移,可以在线操作. 1.将对应表空间offline,移动数据文件到新路径 2.数据文件alter database rename file '' to ''; 3.再将表空间online 情景二:所有数据文件迁移. 本文是针对情景二的实验,需求:主机/oradata挂节点变更为/usr2.在/usr2建立oradata文件夹来存放之前/oradata的所有文件. 操作步骤: 1.查看当前数据库的数据文件,临