用MySQL.Data.dll操作MySQL数据库时,自动添加换行符“\”的问题
时间:2011-08-05
来源:互联网
用MySQL.Data.dll操作MySQL数据库,向数据库中存储数据时,如果数据类型是string,而且其中包含中文的‘和’时(特别是两个一起出现),MySQL.Data.dll会自动给字符串添加换行符“\”。谁有方法让它不自动添加换行符“\”?
添加换行符“\”的原因在MySql.Data.Types.MySqlString的EscapeString方法中:
void IMySqlValue.WriteValue(MySqlStream stream, bool binary, object val, int length)
{
string s = val.ToString();
if (length > 0)
{
length = Math.Min(length, s.Length);
s = s.Substring(0, length);
}
if (binary)
{
stream.WriteLenString(s);
}
else
{
stream.WriteStringNoNull("'" + this.EscapeString(s) + "'");
}
}
private string EscapeString(string s)
{
s = s.Replace(@"\", @"\\");
s = s.Replace("'", @"\'");
s = s.Replace("\"", "\\\"");
s = s.Replace("`", @"\`");
s = s.Replace("\x00b4", "\\\x00b4");
s = s.Replace("’", @"\’");
s = s.Replace("‘", @"\‘");
return s;
}
英文“'”添加换行符还可以理解,为什么中文‘’也要添加换行符呢?
作者: xumingxsh 发布时间: 2011-08-05
s = s.Replace("’", @"\’");
s = s.Replace("‘", @"\‘");
这两个去掉试试
插入之前将中文的单引号替换为特殊字符,插入后再替换为中文的单引号
s = s.Replace("‘", @"\‘");
这两个去掉试试
插入之前将中文的单引号替换为特殊字符,插入后再替换为中文的单引号
作者: wwwwb 发布时间: 2011-08-05
EscapeString(string s)是MySQL.Data.dll中的代码,我们无法修改的。我提问中列出的代码是我反编译后的MySQL.Data.dll代码。
作者: xumingxsh 发布时间: 2011-08-05
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28