Я бегу по следующему сценарию, который вызывает у меня немало головных болей, поскольку я не могу найти точное объяснение поведения, которое вижу Я объявил следующее:
struct test_struct
{
long testv1;
char testv2[51];
long testv3;
};
и соответствующая таблица в Oracle 10g:
CREATE TABLE test_table
(
testv1 NUMBER(10, 0),
testv2 VARCHAR(50),
testv3 NUMBER(4, 0)
);
Для доступа к данным в этой таблице у меня есть функция:
bool getTestData(long test_var1, struct test_struct *outStruct)
и здесь я вижу различия, которые мне нужно объяснить, но не могу. Если тело функции выглядит так:
EXEC SQL BEGIN DECLARE SECTION;
long testvar1_param = test_var1;
struct test_struct *resStruct = outStruct;
EXEC SQL END DECLARE SECTION;
EXEC SQL SELECT testv1, testv2, testv3
INTO :resStruct
FROM test_table
WHERE testv1 = :testvar1_param;
Я получаю более медленную производительность, если тело функции выглядит так:
EXEC SQL BEGIN DECLARE SECTION;
long testvar1_param = test_var1;
long *testv1_res = &(outStruct->testv1);
char *testv2_res = outStruct->testv2;
long *testv3_res = &(outStruct->testv3);
EXEC SQL END DECLARE SECTION;
EXEC SQL SELECT testv1, testv2, testv3
INTO :testv1_res, :testv2_res, :testv3_res
FROM test_table
WHERE testv1 = :testvar1_param;
Производительность во втором отличается значительным отрывом.
Кто-нибудь знает, что может объяснить такое поведение?