建表的时候,如果是浮点数,一般设置为 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...
int number; if (int.TryParse(userInput, out number)) { // 输入有效,可以使用number } else { // 输入无效,需要处理错误 } ``` 然后,`c#_textbox_判断`指的是在TextBox控件中进行输入判断。在Windows Forms...
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; } } ...
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 = ...
int number; // 令牌编号 char* value; // 令牌值 } Token; ``` “tncbak”可能是一个特定的后缀或者项目代号,它可能是程序或项目的名称的一部分,或者表示这是一种备份版本。在实际的编程项目中,我们通常会为...
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...
else if (intNumber[j] >= 65 && intNumber[j] ) // 大写字母A-Z { strAsciiName += Convert.ToChar(intNumber[j]).ToString(); } else if (intNumber[j] >= 97 && intNumber[j] ) // 小写字母a-z { ...
int number1=0; int number2=0; int product; firstNumber=JOptionPane.showInputDialog("输入乘数"); secondNumber=JOptionPane.showInputDialog("shurubeichengshu"); try{ number1=Integer....
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 ...
else if (intNumber[j] >= 97 && intNumber[j] ) // 小写字母a-z { strAsciiName += (char)intNumber[j]; } else // 其他ASCII值不计入 { continue; } } return strAsciiName; } ``` 这里采用了简单的...
public static int splitNumber(int number) { // ... } } ``` ##### 2. 主方法`main` 主方法中定义了四个整型变量`number1`至`number4`,分别初始化为99、81、65和30。然后依次调用`splitNumber`方法对这些...
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) { ...
int number1; /*产品编号*/ char name1[10]; /*产品姓名*/ int number2; /*产品类型编号*/ char name2[10]; /*产品规格*/ char name3[10]; /*计量单位*/ int d2; /*产品数量*/ int d3; /*参考价格*/ struct ...
public static int generateNumber(int base, int length) { int number = 0; for (int i = 0; i ; i++) { number = number * 10 + base; } return number; } } ``` #### 完数查找(程序9) - **知识点**...
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 { // 如果不在以上范围内,则跳过 } } } } ``` 上述代码...
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...
char *week2(int number) { switch(number) { case 0: return "星期日"; case 1: return "星期一"; case 2: return "星期二"; case 3: return "星期三"; case 4: return "星期四"; case 5: return "星期五";...