返回首页

gbase数据、南大通用产品文档:GBase8a18:49:

更新日期:2024年09月11日

node (172.168.83.14)
Recover begin

dectoasc() 函数将 decimal 类型数值转换为 C char 类型值。
语法
mint dectoasc(dec_val, strng_val, len, right)
dec_t *dec_val;
char *strng_val;
mint len;
mint right;
dec_val
指向 dectoasc() 将其值转换为文本字符串的 decimal 结构的指针。
strng_val
指向 dectoasc() 函数放置文本字符串所在的字符缓冲区的第一个字节的指针。
len
以字节计的 strng_val 的大小,对于空终止符,为负 1。
right
指示小数点右边小数位的数目的整数。

用法
如果 right = -1,dec_val 的小数确定小数位的数目。

如果 decimal 数目不适于长度 len 的字符串,则 dectoasc()() 将该数值转换为指数
表示方法。如果该数目仍不适合,则 dectoasc() 以星号填充该字符串。如果该数目比字符
串段,则 dectoasc() 左向调整该数值,并以空格补在右边。

由于 dectoasc()() 返回的字符串不是以空结尾的,因此,在您打印它之前,您的程序
必须将空字符添加到该字符串。


GBase 8s ESQL/C 编程指南
南大通用数据技术股份有限公司
- 658 -

返回代码
0
转换成功。
-1
转换失败。

示例

demo 目录中的文件 dectoasc.ec 包含下列样例程序。
/*
* dectoasc.ec *

The following program converts DECIMAL numbers to strings of varying sizes.
*/

#include

EXEC SQL include decimal;

#define END sizeof(result)

char string1[] = "-12345.038782";
char string2[] = "480";
char result[40];

main()
{
mint x;
dec_t num1, num2;

printf("DECTOASC Sample ESQL Program running.\n\n");


GBase 8s ESQL/C 编程指南
南大通用数据技术股份有限公司
- 659 -

printf("String Decimal Value 1 = %s\n", string1);
if (x = deccvasc(string1, strlen(string1), &num1))
{
printf("Error %d in converting string1 to DECIMAL\n", x);
exit(1);
}
printf("String Decimal Value 2 = %s\n", string2);
if (x = deccvasc(string2, strlen(string2), &num2))
{
printf("Error %d in converting string2 to DECIMAL\n", x);
exit(1);
}

printf("\nConverting Decimal back to ASCII\n");
printf(" Executing: dectoasc(&num1, result, 5, -1)\n");
if (x = dectoasc(&num1, result, 5, -1))
printf("\tError %d in converting DECIMAL1 to string\n", x);
else
{
result[5] = '\0'; /* null terminate */
printf("\tResult ='%s'\n", result);
}

printf("Executing: dectoasc(&num1, result, 10, -1)\n");
if (x = dectoasc(&num1, result, 10, -1))
printf("Error %d in converting DECIMAL1 to string\n", x);
else
{
result[10] = '\0'; /* null terminate */
printf("\tResult = '%s'\n", result);
}

printf("Executing: dectoasc(&num2, result, END, 3)\n");

GBase 8s ESQL/C 编程指南
南大通用数据技术股份有限公司
- 660 -

if (x = dectoasc(&num2, result, END, 3))
printf("\tError %d in converting DECIMAL2 to string\n", x);
else
{
result[END-1] = '\0'; /* null terminate */
printf("\tResult = '%s'\n", result);
}

printf("\nDECTOASC Sample Program over.\n\n")
}
输出

DECTOASC Sample ESQL Program running.

String Decimal Value 1 = -12345.038782
String Decimal Value 2 = 480

Converting Decimal back to ASCII
Executing: dectoasc(&num1, result, 5, -1)
Error -1 in converting decimal1 to string
Executing: dectoasc(&num1, result, 10, -1)
Result = '-12345.039'
Executing: dectoasc(&num2, result, END, 3)
Result = '480.000'
DECTOASC Sample Program over.

ON-Bar 消息编号的范围从 -43000 到 -43421。
下表列出 ON-Bar 消息组。由于活动日志中不显示消息编号,因此要查找有关 ON-Bar 消
息的信息,最佳方法是在 $GBS_HOME/msg 目录下您语言环境的子目录中的错误消息文
件中搜索消息文本。
ON-Bar 消息类型
消息编号
ON-Bar 用法
-43000 到 -43007 和 -43357
选项检查
-43010 到 -43034
权限检查
-43035 到 -43039
紧急引导文件接口
-43040 到 -43059
onconfig 文件接口
-43060 到 -43074
操作系统接口
-43075 到 -43099
数据库服务器接口
-43100 到 -43229
备份与恢复状态
-43230 到 -43239
onbar-worker 进程
-43240 到 -43254
XBSA 接口
-43255 到 -43301
onsmsync
-43302 到 -43319
archecker
-43320 到 -43334
ondblog
-43400 到 -43424