找出数据库中的某个域最接近给定值的上、下值

//摘自网上
function GetNearValue(tblName,fldName,confldName,confldValue:string; GivenValue:Double;

                      var LowValue, HighValue:Double):Boolean;

var
  s:string;

begin
  Result:=False;
  s:='SELECT Max_V,Min_V FROM '+
     '(SELECT MAX('+fldName+') AS Max_V FROM '+tblName+
     ' WHERE ('+fldName+'<='+ FloatToStr(GivenValue)+') AND ('+confldName+'= '''+confldValue+''')) AS Max_Tbl,'+
     '(SELECT MIN('+fldName+') AS Min_V FROM '+tblName+
     ' WHERE ('+fldName+'>='+ FloatToStr(GivenValue)+') AND ('+confldName+'= '''+confldValue+''')) AS Min_Tbl';
  with frmDM.adoqryTmp do
  begin
    Close;
    SQL.Clear;
    SQL.Add(s);
    try
      Open;
      if RecordCount > 0 then
      begin
        LowValue:=VarToFloat(FieldValues['Min_V']);
        HighValue:=VarToFloat(FieldValues['Max_V']);
        Close;
        Result:=True;
      end;  
    except
      Close;
    end;  
  end;
end; 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值