> 데이터 베이스 > MySQL 튜토리얼 > PL/SQL PLS_INTEGER类型对性能实验测试

PL/SQL PLS_INTEGER类型对性能实验测试

WBOY
풀어 주다: 2016-06-07 17:25:22
원래의
1070명이 탐색했습니다.

如果用PLS_INTEGER值运算,Oracle会使用原生机器算法其他的所有数值型的数据类型都和NUMBER数据类型一样使用C语言算法库结果就是

如果用PLS_INTEGER值运算,,Oracle会使用原生机器算法

其他的所有数值型的数据类型都和NUMBER数据类型一样使用C语言算法库

结果就是PLS_INTEGER值的处理速度比NUMBER型的整数快很多

而且,PLS_INTEGER在移植硬件平台时不会遇到兼容性问题

对于密集型的整数运算,Think建议大家使用PLS_INTEGER

不过,如果频繁的PLS_INTEGER和NUMBER型的数据交互,还是建议一开始就使用NUMBER

如果对精度有要求,也请不要使用,因为PLS_INTEGER用于整数运算,结果会取整

小实验测试一下:

hr@ORCL> ed
Wrote file afiedt.buf

  1  DECLARE
  2    j PLS_INTEGER :=0;
  3  BEGIN
  4    FOR i IN 1..1000000
  5      LOOP
  6        j:=i+1;
  7        IF j=1000
  8        THEN
  9          dbms_output.put_line('Hello Think');
 10        END IF;
 11      END LOOP;
 12* END;
hr@ORCL> /
Hello Think

PL/SQL procedure successfully completed.

Elapsed: 00:00:00.28
hr@ORCL> ed
Wrote file afiedt.buf

  1  DECLARE
  2    j NUMBER :=0;
  3  BEGIN
  4    FOR i IN 1..1000000
  5      LOOP
  6        j:=i+1;
  7        IF j=1000
  8        THEN
  9          dbms_output.put_line('Hello Think');
 10        END IF;
 11      END LOOP;
 12* END;
hr@ORCL> /
Hello Think

PL/SQL procedure successfully completed.

Elapsed: 00:00:00.36

linux

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿