数据库

本类阅读TOP10

·SQL语句导入导出大全
·SQL Server日期计算
·SQL语句导入导出大全
·SQL to Excel 的应用
·Oracle中password file的作用及说明
·MS SQLServer OLEDB分布式事务无法启动的一般解决方案
·sqlserver2000数据库置疑的解决方法
·一个比较实用的大数据量分页存储过程
·如何在正运行 SQL Server 7.0 的服务器之间传输登录和密码
·SQL中两台服务器间使用连接服务器

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
传递和返回数据到一个Delphi编写的UDF

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

[UDF系列之四]:传递和返回数据到一个Delphi编写的UDF
Warton译
作者: Chris Levesque, Tina Grubbe, Brett Bandy


--------------------------------------------------------------------------------


[译者叙]:

前面我已经翻译了几篇关于编写UDF的文章,虽然一些朋友可能也从中得到了一点帮助,但是可能对UDF的
认识还存在一些问题。今天,我再翻译两文章,这两篇文章都是来自MER System (http://www.mers.com)
的,有兴趣的朋友可以查看原文。

 
[论点]:
        当动态链接库没有为受保护的数据值做特殊的预防时,我们的UDF带有参数值或返回值的数据结果
可能处在一个受保护的异常或错误结果之中。
 
[解决方案]:
        每一个日期值被保存在两个32位的整数类型之中:一个表示日期的signed integer,和一个表示
时间的unsigned integer。使用Delphi代码来定义这个结构(ISC_QUAD)和结构的指针(PISC_QUAD):
type
    {InterBase Date/Time Record}
    ISC_QUAD = record
       isc_quad_high : Integer ;  // Date
       isc_quad_low  : Cardinal ; // Time
       end;
    PISC_QUAD = ^ISC_QUAD;
    为了保护返回值,在函数定义的外部申明一个线程安全的ISC_QUAD变量,使它保存返回值(如果返回值
是一个日期型的数据)。
threadvar
    tempquad : ISC_QUAD;
然后编写你的函数以便结果指向线程变量。
 
 // 定义函数
// This function adds a number of days to an existing date.
 function DayAdd( var Days: Integer; IBDate PISC_QUAD) : PISC_QUAD; cdecl; export;
 
 begin
    tempquad.isc_quad_high := IBDate^.isc_quad_high + Days;
    tempquad.isc_quad_low  := IBDate^.isc_quad_low;
    Result := @tempquad;
 end;
 
  
 
本主来自:MER Systems Inc..  http://www.mers.com

 




相关文章

相关软件