0

任何人都可以帮助给出一个使用自定义类型作为参数之一的 C 语言函数示例吗?

今天,我尝试按照文档进行操作,但无法获得自定义类型的正确值。

示例如下: http://www.postgresql.org/docs/9.3/static/xfunc-c.html#XFUNC-C-BASETYPE

#include "postgres.h"
#include "executor/executor.h"  /* for GetAttributeByName() */

#ifdef PG_MODULE_MAGIC
PG_MODULE_MAGIC;
#endif

PG_FUNCTION_INFO_V1(c_overpaid);

Datum
c_overpaid(PG_FUNCTION_ARGS)
{
    HeapTupleHeader  t = PG_GETARG_HEAPTUPLEHEADER(0);
    bool isnull;
    Datum salary;

    salary = GetAttributeByName(t, "salary", &isnull);
    if (isnull)
        PG_RETURN_BOOL(false);

    PG_RETURN_FLOAT4(DatumGetFLOAT4(salary) );
}

答案总是“0”。

你可以使用“CREATE TYPE V AS(salary float);” 作为自定义类型。谢谢。

4

1 回答 1

0

上述问题已解决。

这是字节数的问题。

我介绍了 double 类型,但是使用 FLOAT4 来获取值。我应该使用 FLOAT8 来获得正确的值。

2016-03-05

于 2016-03-05T07:55:03.770 回答