微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

delphi – ADO组件,特别是TADOCommand,在某些情况下使用未命名或命名的参数更可靠地工作?

StackOverflow有几个问题似乎有相互矛盾的ADO / OleDB,delphi TADOQuery / TADOCommand和参数的主题的答案。

参数可以引入两种方式,在ADT组件的CommandText或sql属性中。命名参数,它在大多数时间为我工作,带有冒号:

select a,b,c from bar where bat = :baz

这工作,99%的时间对我来说,只是罚款。每时每刻,我发现ADO或Delphi的包装器,它不会接受“:baz”,并要求我写这个改为:

select f,g,h from bar where bat = ?

这导致一个未命名的参数,而不是一个命名的参数。当ADO查询或ADO命令只包含一个参数时,这不是一个大问题。但这不是当ADO行动在我。昨天它采取了一种方式,今天,在一个单独的TADOCommand对象中使用双重命令的不同方式,像这样,在一个CommandText字符串中有两个命令:

delete from bar where id = :id1
delete from bat where id = :id2

我不得不改为:

delete from bar where id = ?
delete from bat where id = ?

它昨天工作整天。今天,我不得不改回第一个版本,让它工作。症状是ADO参数消失,不会回来,当我尝试执行命令时,得到一个错误,索引超出范围,当我尝试访问参数[0]。没有什么可以告诉我这些参数会消失。看来,在设计时,与ADO数据集的几个连接,特别是慢跑TADOCommand组件,它“只是打破了我”。当你试图写一个查询一个命令,你知道它是有效的,但是ADO组件决定不接受“?或“:x”。你可以通过从一个切换到另一个来避开其完全无法工作。但是这让我感到沮丧,可能实际上完全阻挡了其他人。我知道一些人总是在代码中动态构建他们的sql,并避免使用参数,也许这就是为什么。

对我预期的问题的可能答案是:

> ADO不支持多个命令,或者至少Delphi的包装器不支持。或者也许TADOCommand在这里不能可靠地工作。
>参数是所有ADO中的一个有缺陷的区域,或者所有Delphi的ADO包装器?
>你做错了。

我使用Delphi XE2,但我在2007,2009,2010和XE也看到类似的狡猾行为。
我正在使用Microsoft OLEDB Provider for sql Server作为我的OLEDB Provider。

解决方法

命名参数:?我总是使用它与@,甚至在Visual Studio(ADO.NET)。
而在T-sql参数和变量前面加上@。

不记得有问题了…你确定你不选择Native Client(安装有sql Server客户端安装),而不是sql Server的OLEDB提供程序(其中自带的Windows)?

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


 从网上看到《Delphi API HOOK完全说明》这篇文章,基本上都是大家转来转去,原文出处我已经找不到了。这篇文章写的很不错,但最后部分“PermuteFunction 的终极版本”描述的不太清楚,完全按照该文章代码执行,是不行的。可能是作者故意这样做的?本文最后提供修正后的下载地址。原文如下:一、关于API Hook1.什么是API Hook不知道大家是否还记得,在DO
  从网上看到《Delphi API HOOK完全说明》这篇文章,基本上都是大家转来转去,原文出处我已经找不到了。 这篇文章写的很不错,但最后部分“PermuteFunction 的终极版本”描述的不太清楚,完全按照该文章代码执行,是不行的。需要修改mess.pas中代码才行。其实文中提到的一个结构,代码中并没有使用typePIMAGE_IMPORT_DESCRIPTOR = ^IMA
ffmpeg 是一套强大的开源的多媒体库 一般都是用 c/c++ 调用, 抽空研究了一下该库的最新版 ,把部分api 翻译成了dephi版的 记录一下 地址 ffmpegvcl.zip
32位CPU所含有的寄存器有:4个数据寄存器(EAX、EBX、ECX和EDX)2个变址和指针寄存器(ESI和EDI) 2个指针寄存器(ESP和EBP)6个段寄存器(ES、CS、SS、DS、FS和GS)
1 mov dst, src dst是目的操作数,src是源操作数,指令实现的功能是:将源操作数送到目的操作数中,即:(dst) <--(src) 1.dst和src类型必须匹配,即必须同为字节
有三个API函数可以运行可执行文件WinExec、ShellExecute和CreateProcess。 1.CreateProcess因为使用复杂,比较少用。 2.WinExec主要运行EXE文件。如:WinExec('Notepad.exe Readme.txt', SW_SHOW); 3.ShellExecute不仅可以运行EXE文件,也可以运行已经关联的文件。 首先必须引用shellapi
API原型: Declare Function MoveFileEx& Lib "kernel32" Alias "MoveFileExA" (ByVal lpExistingFileName As String, ByVal lpNewFileName As String, ByVal dwFlags As Long) 参数 类型及说明 lpExistingFileName String,欲移
附带通用控件安装方法: ---------- 基本安装 1、对于单个控件,Componet-->install component..-->PAS或DCU文件-->install; 2、对于带*.dpk文件的控件包,File-->Open(下拉列表框中选*.dpk)-->install即可; 3、对于带*.bpl文件的控件包,Install Packages-->Add-->bpl文件名即可; 4
type   TRec=Record     msg:string;     pic:TMemoryStream; end; procedure TForm2.BitBtn1Click(Sender: TObject); var   ms:TMemoryStream;   Rec1,Rec2:TRec;   cc:tmemorystream;   jpg:TJPEGImage; begin   R