如果先有oracle 数据的情况下,怎么对应到C#中的类型。
在oralce 中
在dba_tab_columns表中,
Data_type表示字段类型;
Data_length表示字段类型的长度;
Data_Precision表示字段类型的精度的总长度,如果为null,表示精度的总长度不固定,最长为Data_Length;
Data_scale表示字段类型的精度范围,如果为0,表示只能存储为整数,
如果为null,表示可以存储整数或者浮点数,浮点数位数不确定,
如果为整数,表示存储的精度位数。
查询dba_tab_columns表,发现tab表中ID0字段类型int已经被转换为number(22)。
参考:http://blog.csdn.net/ojuju10/article/details/4576446
在c#中
float 类型可表示精度为 7 位、在大约 1.5 × 10−45 到 3.4 × 1038 的范围内的值。
double 类型可表示精度为 15 位或 16 位、在大约 5.0 × 10−324 到 1.7 × 10308 的范围内的值。
decimal 类型是 128 位的数据类型,适合用于财务计算和货币计算。decimal 类型可以表示具有 28 或 29 个有效数字、从 1.0 × 10−28 到大约 7.9 × 1028 范围内的值。
int 类型表示有符号 32 位整数,其值介于 -2147483648 和 2147483647 之间。(10位)
long 类型表示有符号 64 位整数,其值介于 -9223372036854775808 和 9223372036854775807 之间。(19位)
所以:
最大兼容原则
如果 scale 为null 用 decimal
如果 scale>0
Precision 为 null 用 decimal
Precision <=7 用 float
Precision >7 而且 Precision <=15 用 double
Precision >15 用 decimal
如果 scale==0
Precision 为 null 用 long
Precision <=9 用 int
Precision > 9 而且 Precision <=19 用 long
根据具体业务数据,可以考虑用decimal。