当我使用UTL_FILE.FGETATTR时,块大小每次返回0。我可以获得文件长度等,但块大小返回0。原因是什么,我该如何解决呢?操作系统: Windows 10 DB :19 C
DECLARE
v_fexists BOOLEAN;
v_file_length NUMBER;
v_block_size BINARY_INTEGER;
BEGIN
UTL_FILE.FGETATTR ('TEST_DIR','temp file.txt',v_fexists,v_file_length,v_block_size);
IF v_fexists THEN
DBMS_OUTPUT.PUT_LINE('The file exists');
DBMS_OUTPUT.PUT_LINE('Its length is :'||v_file_length);
DBMS_OUTPUT.PUT_LINE('Its block size is :'||v_block_size);
ELSE
DBMS_OUTPUT.PUT_LINE('The file does not exist!');
END IF;
END;
PL/SQL procedure successfully completed.
The file exists
Its length is :2794
Its block size is :0
发布于 2020-08-30 19:11:37
我只是张贴的答案,每个人都知道,你可以标记问题的答案。这或多或少是我们在评论部分所谈论的一切的回忆。
在Windows平台上,即使文件存在,UTL_FILE.FGETATTR过程也返回0而不是正确的块大小。Windows平台不提供任何系统子程序来获取文件系统I/O块大小,因此它返回0,这是预期的行为。
虽然对9i/10g进行了预测和记录,但在12c、18c和19c上也是可重现的。
https://stackoverflow.com/questions/63611610
复制相似问题