mysql字符串转义函数

Posted on 2011-10-17 11:43 冷锋 阅读(3865) 评论(3)  编辑 收藏 引用 所属分类: linux
在mysql插入数据表,如果数据中带有'\“会造成语法错误,这个不用解释,你懂的,因此需要写个转义函数,一开始想直接用string的replace,但是这个方法要调用3次
放在服务端感觉效率太低了,于是用C写了个,感觉还可以,时间复杂度跟需要转义字符的个数无关,如果源串没有匹配的话不需要copy操作.
//转义函数,‘转成\'
bool ConverToDBStr( const char* src,char*dst )
{
    
int i = -1;//记录上次匹配的位置
    int dOffset = 0;//目标字符串游标
    int nCopy = 0;//本次需要成 copy的字节数
    const char*= src;
    
while*p )
    {
        
if*p=='\\'||*p=='\''||*p=='"' )
        {
            nCopy 
= p-src-i-1;
            memcpy( dst
+dOffset,src+i+1,nCopy );
            dOffset
+=nCopy;
            
*(dst+Offset)='\\';
            
*(dst+dOffset+1)=*p;
            dOffset
+=2;
            i 
= p-src;
        }
        p
++;
    }
    
if( dOffset>0 )//有匹配到,copy最后的字符串
    {
        memcpy( dst
+dOffset,src+i+1,p-src-i );
        
return true;
    }
    
return false;
}
可以看到,这个函数稍微改动下就可以实现replace

Feedback

# re: mysql字符串转义函数  回复  更多评论   

2011-10-18 22:06 by Glueless full lace wigs for black women
不错,比php的效率要高多了

# re: mysql字符串转义函数  回复  更多评论   

2011-10-19 09:07 by zuhd
不用mysql的逃脱函数?

# re: mysql字符串转义函数  回复  更多评论   

2011-10-19 09:54 by 冷锋
刚发现有这种函数,不过我是在应用层做的,主要是要转义文件名中的单引号,觉得比较简单,就自己写了个。@zuhd

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理


posts - 15, comments - 18, trackbacks - 0, articles - 0

Copyright © 冷锋