Delphi中使用动态SQL的几个问题

Delphi支持参数化SQL语句,不过俺很少用Paramters/Params属性,一般都是自己构造SQL,
用SQL.Text:='Select * from ..Where ID='''+edit1.text+'''';
不过这种方法要小心SQL注入攻击哦。
今天改用ADOQuery控件的Paramters属性,本已为简单的很,一用发现了不少问题。由于我只使用一个ADOQuery控件,而其中的SQL语句和语句中的参数经常要变,所以刚开始在程序中用了如下代码:
..........
ADOQ.Parameters.Clear;
ADOQ.Parameters.CreateParameter(...); //创建参数1
ADOQ.Parameters.CreateParameter(...); //创建参数2
ADOQ.SQL.Clear;
ADOQ.SQL.Assign(memo1.text);

............

可一执行,就有时正常,有时报错,说什么不正确的参数设置(用的ACCESS)。
经过两天的折腾,发现必须使用下面的代码(真是奇怪):
..........
ADOQ.Parameters.Clear;
Parami:=ADOQ.Parameters.ADDParameter; //创建参数1
Parami.Name:=...;  Parami.Value:=... 
Parami:=ADOQ.Parameters.ADDParameter; //创建参数2
Parami.Name:=...;  Parami.Value:=... 
        //ADOQ.SQL.Clear;  // 该句不能使用,
ADOQ.SQL.Assign(memo1.text);
............


还有创建参数的名称不仅要和SQL语句中的参数名称一致,创建参数的顺序也要和SQL语句中参数出现的顺序一致
从Delphi的帮助上也没发现什么,真是不理解,还有如果SQL 语句是非Select形则两种方法均可。
???
准备阅读Delphi ADOQuery的源代码
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值