首页 新闻 会员 周边

用MySQL.Data.dll操作MySQL数据库时,自动添加换行符“\”的问题

0
悬赏园豆:50 [待解决问题]

用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访问数据库的时候,都应该会遇到这个问题吧?大家是怎么处理的呢?

荣-的主页 荣- | 初学一级 | 园豆:25
提问于:2011-08-05 09:39
< >
分享
所有回答(1)
0

在什么地方添加换行符?

顾晓北 | 园豆:10844 (专家六级) | 2011-08-05 10:59
清除回答草稿
   您需要登录以后才能回答,未注册用户请先注册