• 全部
  • VC综合技术
  • 互联网技术
  • MFC AppLauncher
  • .NET 技术
  • 界面
  • 进程
  • 算法
  • 硬件/系统
  • 数据库
  • VC++技术资源

高手请帮帮忙,关于SQL语句的问题。

laiping 2001-07-11 12:04:52
我在一个循环中,每循环一次就执行一个SQL语句往数据库中插入一条记录,格式如下:
strSql.Format("insert into Resources (a1,a2,a3) values ('%s','%s','%s')",
s1,s2,s3);
p_dbs.ExecuteSQL(strSql);
可是我发现如果某一个变量的值中带有半角的一撇“'”的,就出现SQL语句语法错误的提
示,然后终止循环,请问怎么解决?或者怎么让它跳过去,继续循环?
...全文
81 点赞 收藏 10
写回复
10 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
laiping 2001-07-11
感谢各位,我去试试
回复
neomeng 2001-07-11
简单。捕获错误。

try{
m_TTUdata.ExecuteSQL(sSql);
}
catch(CDBException *e)
{
//AfxMessageBox(e->m_strError);
e->Delete();
在这里进行错误处理 。比如继续循环:continue;
}
回复
runbuff 2001-07-11
gz
回复
建议用带参数的SQL语句
strSql.Format("insert into Resources (a1,a2,a3) values (?, ?, ?)");
你如果用ADO的话,创建_CommandPtr智能指针,调用他的方法CreateParameter创建Parameter!
回复
windindance 2001-07-11
用双引号不行呀,某一个变量的值中带有半角的双引号"也会有错误的。
你应先把字符串内的引号替换为:''(两个单引号)就可以了。
回复
laiping 2001-07-11
Hopping:
在变量里用双引号吗?可我不知道变量的内容啊?是从一个文件里截取出的一些字符啊?

怎么让它提示错误再继续循环啊?
回复
Hopping 2001-07-11
用雙引號不就得了
回复
laiping 2001-07-11
我试了,用两个单引号好使,用反斜杠加单引号不好使
回复
不解 2001-07-11
如果不想中断的话,只能捕获错误,同neomeng(大胖)的建议;
我想应该在形成SQL语句之前对s1,s2,s3的值进行处理,搜索“‘”
然后在结果前插入“\",就可以解决"'"造成的SQL语法问题。
回复
flagfly 2001-07-11
windindance(风之舞)的方法不知道可不可以,我觉得应该是把它替换为\'。
回复
相关推荐
发帖
VC/MFC
创建于2007-09-28

1.5w+

社区成员

VC/MFC相关问题讨论
申请成为版主
帖子事件
创建了帖子
2001-07-11 12:04
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……