返回首页

gbase数据、南大通用产品文档:GBase8c参数说明

更新日期:2024年09月11日


GBase 8c 工具参考手册
南大通用数据技术股份有限公司
VIII

日志记录的 sbspace(SQL 管理 API)
随同 admin() 或 task() 函数,使用 create sbspace with log 参数来创建启用事务日
志记录的 sbspace。
语法

元素
描述
关键考虑
initial_chunk_size
新 sbspace 的初始 chunk 的大小,以
KB 为单位。
请参阅 admin() 和
task() 参数大小规范。
offset
磁盘分区内或设备内达到新 sbspace 的
初始 chunk 的偏移量,以 KB 为单位。


GBase 8s 管理员参考
南大通用数据技术股份有限公司 - 724 -
元素
描述
关键考虑
path_name
该 sbspace 的初始 chunk 的磁盘分区
或无缓冲的设备。

sbspace
要创建的 sbspace 名。


用法
使用 create with_check sbspace 参数来检查指定的路径名,如果路径不存在,则返回错
误。
这个函数等同于 onspaces -c -S 命令来创建开启日志记录的 sbspace。
示例
下列示例创建开启事务日志记录的新 sbspace。
该 sbspace 的大小为 20
MB,
偏移量为 0:

EXECUTE FUNCTION task ("create sbspace with log","sbspace2",
"$GBASEDBTDIR/WORK/sbspace2","20 M","0");

ifx_int8add() 函数将两个 int8 类型值相加。
语法
mint ifx_int8add(n1, n2, sum)
ifx_int8_t *n1;
ifx_int8_t *n2;
ifx_int8_t *sum;
n1
指向包含第一个操作对象的 int8 结构的指针。
n2
指向包含第二个操作对象的 int8 结构的指针。
sum
指向包含 n1 + n2 的和的 int8 结构的指针。

用法
sum 可与 n1 或 n2 相同。


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

返回代码
0
运算成功。
-1284
运算导致溢出或下溢。

示例
demo 目录中的文件 int8add.ec 包含下列示例程序。
*int8add.ec *

The following program obtains the sum of two INT8 type values.
*/

#include

EXEC SQL include "int8.h";

char string1[] = "6";
char string2[] = "9,223,372,036,854,775";
char string3[] = "999,999,999,999,999,9995";
char result[41];

main()
{
mint x;
ifx_int8_t num1, num2, num3, sum;

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

if (x = ifx_int8cvasc(string1, strlen(string1), &num1))
{
printf("Error %d in converting string1 to INT8\n", x);

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

exit(1);
}
if (x = ifx_int8cvasc(string2, strlen(string2), &num2))
{
printf("Error %d in converting string2 to INT8\n", x);
exit(1);
}
if (x = ifx_int8add(&num1, &num2, ∑)) /* adding the first two INT8t */
{
printf("Error %d in adding INT8t\n", x);
exit(1);
}
if (x = ifx_int8toasc(∑, result, sizeof(result)))
{
printf("Error %d in converting INT8 result to string\n", x);
exit(1);
}
result[40] = '\0';
printf("\t%s + %s = %s\n", string1, string2, result); /* display result */

/* attempt to convert to INT8 value that is too large*/

if (x = ifx_int8cvasc(string3, strlen(string3), &num3))
{
printf("Error %d in converting string3 to INT8\n", x);
exit(1);
}
if (x = ifx_int8add(&num2, &num3, ∑))
{
printf("Error %d in adding INT8t\n", x);
exit (1);
}
if (x = ifx_int8toasc(∑, result, sizeof(result)))

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

{
printf("Error %d in converting INT8 result to string\n", x);
exit(1);
}
result[40] = '\0';
printf("\t%s + %s = %s\n", string2, string3, result); /* display result */

printf("\nINT8 Sample Program over.\n\n");
exit(0);
}
输出
INT8 Sample ESQL Program running.

6 + 9,223,372,036,854,775 = 9223372036854781
Error -1284 in converting string3 to INT8
INT8 Sample Program over.