用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;
        }英文“'”添加换行符还可以理解,为什么中文‘’也要添加换行符呢?

解决方案 »

  1.   

    s = s.Replace("’", @"\’");
    s = s.Replace("‘", @"\‘");
    这两个去掉试试
    插入之前将中文的单引号替换为特殊字符,插入后再替换为中文的单引号
      

  2.   

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

  3.   

    检查你的字符集。set names 'gbk'; 先试一下。