用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;
}
英文“'”添加换行符还可以理解,为什么中文‘’也要添加换行符呢?
我向数据库中保存“test‘’”,数据库中保存的真实值是“test‘\’”
大家在用MySQL.Data.dll访问数据库的时候,都应该会遇到这个问题吧?大家是怎么处理的呢?
在什么地方添加换行符?