+ -
当前位置:首页 → 问答吧 → 用MySQL.Data.dll操作MySQL数据库时,自动添加换行符“\”的问题

用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("‘", @"\‘");
这两个去掉试试
插入之前将中文的单引号替换为特殊字符,插入后再替换为中文的单引号

作者: wwwwb   发布时间: 2011-08-05

EscapeString(string s)是MySQL.Data.dll中的代码,我们无法修改的。我提问中列出的代码是我反编译后的MySQL.Data.dll代码。

作者: xumingxsh   发布时间: 2011-08-05