`

int number

 
阅读更多
建表的时候,如果是浮点数,一般设置为 number(m,n )[m为精度,n为小数位数,所以整数为m-n位],  整数设置为integer;

比如:

create table abc
(  a number(38,0),
   b number(38)
   c integer,
   d number
)

那么a,b,c,d 分别有什么区别呢?
a,b其实是一样的,都是38位的范围;
c是不是和a,b一样呢?测试后是不一样的,c的最大值可以达到9e125,显然远远地大于38位的范围;
d和a,b,c有什么区别呢,首先d可以放小数,另外它的范围同样远远大于38位;

具体这a,b,c,d四种类型的明确差异,我也说不清楚,希望有专家把它解释清楚,我这里只是抛砖引玉。


以前我一直以为 integer=number(38,0) --38是number的最大精度

刚才无意中发现integer 是个超大的数据类型,最大可以表示为power(10,126)-1
也就是说这么大的数字,大概需要多少个字节呢,

因为一个字节最大表示256,那么N个字节最大表示power(256,n)>=power(10,126)

现在求这个N:解法是:
   select  LOG(256,10)*126   from dual
求得的解是 53, 也就是说,一个integer类型最少使用53个字节。



所以我觉得Integer类型还是尽量少用,一般很少用到这么大的数字;



特别是某些人对于boolean类型的处理;

因为Oracle的表结构中没有布尔类型,所以很多人干脆用integer 代替布尔类型,这个感觉有点“奢侈”;

我一般都用char(1)表示布尔型;'0'表示false,'1'表示true



另外,比如varchar2(200)这个类型,它是动态分配的,所以字符串按实际使用的占用空间,但是integer却是固定暂用了最少53个字节,所以大部分时候,integer 类型还是不用为妙;

就算在pl/sql 里;
定义变量的时候,也不要使用integer;
可以用binary_integer 或pls_integer ;11g里还出了个新的整形,效率更高,叫simple_integer,反正最好不用integer就是了。

效率测试下来:simple_integer>pls_integer>binary_integer>integer;
分享到:
评论

相关推荐

    实验二 模拟页面置换过程(实验报告+源代码)

    int number; int offset; }; class CPage { private: int MAXN ; int size of v ; int size of vp ; int size of m ; int size of mp ; int max vp; int max mp; int lacks; PAGE vp adr; int mp flag...

    使用函数输出水仙花 C语言.docx

    int isNarcissistic(int number) { int originalNumber = number; int numberOfDigits = 0; int sum = 0; // 计算数字的位数 while (originalNumber != 0) { originalNumber /= 10; numberOfDigits++; } ...

    Python第二章节基础语法练习。

    intnumber = int(floatnumber) print(intnumber) print(type(intnumber)) strnumber = str(intnumber) print(strnumber) print(type(strnumber)) #5. a = int(input("please input a number:")) a = a//3 print(a)...

    java期末上机复习题目及其答案

    java期末上机复习题目及其答案 针对考试专用

    StudentTest.java

    void enterMarks(int markForMaths, int markForEnglish, int markForScience) int getMathsMark() int getEnglishMark() int getScienceMark() double calculateAverage() String toString() 返回学生信息,...

    水仙花数c语言程序.docx

    int countDigits(int number) { int count = 0; while (number != 0) { number /= 10; count++; } return count; } // 函数用于判断一个数是否为水仙花数 int isNarcissistic(int number) { int ...

    C语言做的九宫盒游戏

    int getBoxNumber(char *number); void setBox(int i,int j,char *number); void disBox(int yX,int yY); void moveBox(int nX,int nY); int cheakBoxL(int l); int cheakBoxH(int h); int cheakBox(); void success...

    java假期练习程序.rar

    int number1=0; int number2=0; int product; firstNumber=JOptionPane.showInputDialog("输入乘数"); secondNumber=JOptionPane.showInputDialog("shurubeichengshu"); try{ number1=Integer....

    基于Java写的猜数字

    int number=(int)(Math.random()*100);//0-100的随机数 while(number!=count) { count=Integer.parseInt(JOptionPane.showInputDialog("guess a number between 0 amd 100")); if(number>count) { ...

    c语言课程设计-产品管理系统.rar

    int number1; /*产品编号*/ char name1[10]; /*产品姓名*/ int number2; /*产品类型编号*/ char name2[10]; /*产品规格*/ char name3[10]; /*计量单位*/ int d2; /*产品数量*/ int d3; /*参考价格*/ struct ...

    华容道java 程序

    import java.awt.*; import java.awt.event.*; public class MoveExample ...Person(int number,String s) { super(s); setBackground(c); this.number=number; c=getBackground(); addFocusListener(this); }

    C_语言_math函数库手册

    C库函数汇总,例如: 函数名称: abs 函数原型: int abs(int x); 函数功能: 求整数x的绝对值 函数返回: 计算结果 ...int number=-1234; printf("number: %d absolute value: %d",number,abs(number)); return 0; }

    很好的C语言课程设计源码

    int number[210][5]; /*存放可逆素数及素数分解后的各位数字*/ int select[110]; /*可以放在矩阵第一行和最后一行的素数的下标*/ int array[4][5]; /*4X4的矩阵,每行0号元素存可逆素数对应的数组下标*/ int count;...

    使用函数输出水仙花 文字版

    int narcissistic( int number ); void PrintN( int m, int n ); 函数narcissistic判断number是否为水仙花数,是则返回1,否则返回0。 函数PrintN则打印开区间(m, n)内所有的水仙花数,每个数字占一行。题目保证100...

    c编程 万年历

    char *week2(int number) { switch(number) { case 0: return "星期日"; case 1: return "星期一"; case 2: return "星期二"; case 3: return "星期三"; case 4: return "星期四"; case 5: return "星期五";...

    C语言程序设计经典例子

    int number[20],n,m,i; printf("the total numbers is:"); scanf("%d",&n); printf("back m:"); scanf("%d",&m); for(i=0;i;i++) scanf("%d,",&number[i]); scanf("%d",&number[n-1]); move(number,n,m); ...

    Java 2实用教程(第三版)实验指导与习题解答

    int realNumber=(int)(Math.random()*100)+1; int yourGuess=0; String str=JOptionPane.showInputDialog("输入您的猜测:"); yourGuess=Integer.parseInt(str); while(yourGuess!=realNumber) //循环条件 ...

    Hce300B 动态连接库

    1、int ReadCard(int portnumber,int tracknumber,int timeout,unsigned char* track1,int* track1len,unsigned char* track2,int* track2len,unsigned char* track3,int* track3len) 2、int WriteCard(int port...

    C语言查找数组里数字重复次数的方法

    本文实例讲述了C语言查找数组里数字重复次数的方法。分享给大家供大家参考。具体如下: #include stdafx.h ... int number=0; cin>>number; int count=0; for(int i=0;i<sizeof(myarray);i++) { if(number=

    C语言排序代码

    main(){int number[10];input(number);max_min(number);output(number);}input(number)int number[10];{int i;for(i=0;i;i++) scanf("%d,",&number;[i]); scanf("%d",&number;[9]);}max_min(array)int array[10];{...

Global site tag (gtag.js) - Google Analytics