decsub() 函数将两个 decimal 类型值相减。
语法
mint decsub(n1, n2, difference)
dec_t *n1;
dec_t *n2;
dec_t *difference;
n1
指向第一个运算对象的 decimal 结构的指针。
n2
指向第二个运算对象的 decimal 结构的指针。
GBase 8s ESQL/C 编程指南
南大通用数据技术股份有限公司
- 655 -
difference
指向包含 n1 减去 n2 的差的 decimal 结构的指针。
用法
difference 可与 n1 或 n2 相同。
返回代码
0
操作成功。
-1200
操作导致溢出。
-1201
操作导致下溢。
示例
demo 目录中的文件 decsub.ec 包含下列示例程序。
/*
* decsub.ec *
The following program subtracts two DECIMAL numbers and displays the result.
*/
#include
EXEC SQL include decimal;
char string1[] = "1000.038782";
char string2[] = "480";
char result[41];
main()
GBase 8s ESQL/C 编程指南
南大通用数据技术股份有限公司
- 656 -
{
mint x;
dec_t num1, num2, diff;
printf("DECSUB Sample ESQL Program running.\n\n");
if (x = deccvasc(string1, strlen(string1), &num1))
{
printf("Error %d in converting string1 to DECIMAL\n", x);
exit(1);
}
if (x = deccvasc(string2, strlen(string2), &num2))
{
printf("Error %d in converting string2 to DECIMAL\n", x);
exit(1);
}
if (x = decsub(&num1, &num2, &diff))
{
printf("Error %d in subtracting decimals\n", x);
exit(1);
}
if (x = dectoasc(&diff, result, sizeof(result), -1))
{
printf("Error %d in converting result to string\n", x);
exit(1);
}
result[40] = '\0';
printf("\t%s - %s = %s\n", string1, string2, result);
printf("\nDECSUB Sample Program over.\n\n");
exit(0);
}
输出
GBase 8s ESQL/C 编程指南
南大通用数据技术股份有限公司
- 657 -
DECSUB Sample ESQL Program running.
1000.038782 - 480 = 520.038782
DECSUB Sample Program over.