`

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...

    CSharp_Int_TextBox.rar_C#int_c# console输入int_c# textbox 判断_c# te

    int number; if (int.TryParse(userInput, out number)) { // 输入有效,可以使用number } else { // 输入无效,需要处理错误 } ``` 然后,`c#_textbox_判断`指的是在TextBox控件中进行输入判断。在Windows Forms...

    StudentTest.java

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

    案例上手设计模式-虾米大王教你学编程

    public int doOperation(int number1, int number2); } public class OperationAdd implements Operation { @Override public int doOperation(int number1, int number2) { return number1 + number2; } } ...

    int、char、double与byte类型之间相互转换

    public static byte[] intToByte(int number) { int temp = number; byte[] b = new byte[4]; for (int i = b.length - 1; i >= 0; i--) { b[i] = new Integer(temp & 0xff).byteValue(); // 获取低8位 temp = ...

    TNC.rar_number_tncbak_token number_token number display

    int number; // 令牌编号 char* value; // 令牌值 } Token; ``` “tncbak”可能是一个特定的后缀或者项目代号,它可能是程序或项目的名称的一部分,或者表示这是一种备份版本。在实际的编程项目中,我们通常会为...

    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...

    C#实现注册机代码,如何取得CPUid等等

    else if (intNumber[j] >= 65 && intNumber[j] ) // 大写字母A-Z { strAsciiName += Convert.ToChar(intNumber[j]).ToString(); } else if (intNumber[j] >= 97 && intNumber[j] ) // 小写字母a-z { ...

    java假期练习程序.rar

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

    丑数c语言,两种解法,详细过程

    int Min(int number1, int number2, int number3){ int min = (number1 < number2) ? number1 : number2; min = (min < number3) ? min : number3; return min; } int GetUglyNumber_Solution(int index){ if ...

    C# 读取机器码,CPU序列号,生成注册码类

    else if (intNumber[j] >= 97 && intNumber[j] ) // 小写字母a-z { strAsciiName += (char)intNumber[j]; } else // 其他ASCII值不计入 { continue; } } return strAsciiName; } ``` 这里采用了简单的...

    拆分数字(java代码).docx

    public static int splitNumber(int number) { // ... } } ``` ##### 2. 主方法`main` 主方法中定义了四个整型变量`number1`至`number4`,分别初始化为99、81、65和30。然后依次调用`splitNumber`方法对这些...

    基于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基础练习50题

    public static int generateNumber(int base, int length) { int number = 0; for (int i = 0; i ; i++) { number = number * 10 + base; } return number; } } ``` #### 完数查找(程序9) - **知识点**...

    check prime_Primenumber_

    int number; printf("Enter a number: "); scanf("%d", &number); if (is_prime(number)) { printf("%d is a prime number.\n", number); } else { printf("%d is not a prime number.\n", number); } ...

    简单制作机器码注册码

    else if (intNumber[j] >= 97 && intNumber[j] ) // 检查是否为小写字母 { strAsciiName += Convert.ToChar(intNumber[j]).ToString(); } else { // 如果不在以上范围内,则跳过 } } } } ``` 上述代码...

    C#_读取机器码_CPU序列号_生成注册码类

    else if (intNumber[j] >= 97 && intNumber[j] ) // 判断字符ASCII值是否a-z之间 { strAsciiName += Convert.ToChar(intNumber[j]).ToString(); } } return strAsciiName; } ``` - **关键代码解析**: - `...

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

    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 "星期五";...

Global site tag (gtag.js) - Google Analytics