• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

delphiAdo执行带有冒号字符语句的处理。

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

用DELPHI的程序员都知道ADO的易用性,用ADO控件操作数据库是非常受欢迎的,但使用ADO也会碰到一些麻烦问题,就像DELPHI 5下如果要用ADO就要先装好ADO补丁,有的SQL的语句在数据库工具里执行可以成功但用DELPHI的AdoQuery执行不一定能成功。今天又碰到这问题:ADO要执行的SQL语句里同时包含有": 时就会有问题,如下面SQL语句:

AdoQuery1.Close;
AdoQuery1.Sql.text:=' Insert  T_SavePartTab(FID, FPart)  Values ('' 0001'' , '' "c:/part1";"d:/part2" '' )';
AdoQuery1.ExecSql;

执行这语句后可能就会提示:不正常地定义参数对象。提供了不一致或不完整的信息。

这是由于ADO控件在解析SQL语句时碰到" 里的: 时认为: 后的是变量,是在参数Parameters[]里进行赋值的变量,而实际上: 我们只是当字符用,这时报出要定义参数显然不是我们想要的。

这个问题的解决方法:

  1、通过替换: 或" 字符为其它字符(如" 替成' );

  2、不让ADO控件检测SQL语句参数变量,AdoQuery1.ParamCheck := false;

这两种情况只能结合实际情况使用,都有弊端这里就不哆嗦了,欢迎大家讨论!


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
matlab脚本 gui设计基础发布时间:2022-07-18
下一篇:
matlab脚本转换为python发布时间:2022-07-18
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap