设为首页 加入收藏

TOP

mysql字符串转义函数
2014-11-24 08:21:44 来源: 作者: 【 】 浏览:3
Tags:mysql 字符串 转义 函数

在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*p = src;
while( *p ) www.2cto.com
{
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

作者:ifeng

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇mysql中字符串或字段中空格函数的.. 下一篇The table‘xxxx’is full 设置临..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·Redis on AWS:Elast (2025-12-27 04:19:30)
·在 Spring Boot 项目 (2025-12-27 04:19:27)
·使用华为开发者空间 (2025-12-27 04:19:24)
·Getting Started wit (2025-12-27 03:49:24)
·Ubuntu 上最好用的中 (2025-12-27 03:49:20)