delphi中使用sql语句加条件引用时值是一个整型变量的问题

SQL为数据库的操作提供了很多方法,结合起delphi,要想按自己的需要得到预想的结果,却要经过SQL测试再到delphi里的语句这样一个过程。

目前我就遇到一个难题:就是在查询语句中使用条件,但条件引用的是一个整型变量(string变量最简单),整型变量却不容易清楚,想到这是遇到的问题,先搞清楚再继续工作。以下是我用的语句(简化了):

var mydata:integer;
……
sql.add(format('select * from stdinfo where grade="%d"',[mydata]));
……

但是不能通过,不知道是哪里来的语句,我是上网看别人的帖子得的。先以为是符号问题,不是这样,我试了几回&和*甚至是^,不对。可能是没有这样的用法,在Q群上,朋友们说是%的引用不对,好像是要sql动态参数传值,而delphi要用:
所以有

sql.add('select * from stdinfo where grade=:p1');
parambyname('p1').asinteger:=mydata;

 利用参数传值,虽然还不太清楚,这个应该试一下吧,但愿一切如意。

经过测试,光是上面的代码也是不对的,应该这样写:

 1 var graden:integer;
 2 begin
 3 graden:=4;//测试用的数据
 4 with adoquery1 do
 5 begin
 6 close;
 7 sql.Clear;
 8 sql.Add('select grade,class,name from stdinfo where grade=:p1');
 9 Parameters.ParamByName('p1').Value:=graden;
10 open;

注意:值得一提的是,SQL语句中条件引用一个变量值时,要用parameters传值,而网上什么asinteger之类的也要视情况而定,我用的paramByname就没有.asinteger的选项,这点可能是delphi版本所至,有的语句可能是delphi 6.0的或其它,我用7.0。

posted @ 2012-11-19 11:29  JTeacher  阅读(1419)  评论(0)    收藏  举报