关于MySQL中FLOAT和DOUBLE类型的存储

其实在单精度和双精度浮点类型存储中其存储方式和C/C++一致准守IEEE标准他们都是浮点型的,所谓的浮点型,是小数点的位置可变,其能够表示的范围比定点小数要广得多,而存储空间节省,但是受到精度的影响,所以在严格的数据中尽量使用定点小数MySQL decimal(m,d)类型,Oracle压根没有浮点数字类型而是number(p,s)定点小数,

float 4字节
    1      8      23
  符号位  指数位 尾数

double 8字节
    1      11    52
    符号位  指数位  尾数
 那么很明显他们的精度取决于尾数。
 而表示的范围取决于指数。

float表示范围:
2^8=(-128—127)
-2^128—2^127
约为-3.4E38—3.4E38
 double表示范围:
2^11=(-1024—1023)
-2^1024—2^1023
约为-1.7E308—1.7E308
可以看到这个范围实际上很广,但是精度确很小
float精度:
float 尾数23位,2^23=8.3E6  6-7位
double尾数52位,2^52=4.5E15 14-15位

那么如果使用浮点数据保存了精度大于其范围的数据其会使用四舍五入的方法截断。
MYSQL如下:
mysql> create table dname(id1 float,id2 double,name varchar(20));
 Query OK, 0 rows affected (0.08 sec)
 mysql> insert into dname values(1234567.123,1234567.123,'gaopeng');
 Query OK, 1 row affected (0.00 sec)
 mysql> commit;
 Query OK, 0 rows affected (0.00 sec)
 mysql> select * from dname;
 +---------+-------------+---------+
 | id1    | id2        | name    |
 +---------+-------------+---------+
 | 1234570 | 1234567.123 | gaopeng |
 +---------+-------------+---------+
 1 row in set (0.00 sec)
虽然进行了四舍五入,但是不会有任何报错和警告,这是其标准决定的而不是数据库本生。
 可以看到1234567.123在FLOAT下被四舍五入为1234570,而DOUBLE类型没有问题,那么我们
 直接从数据文件中提取数据。
 我还是使用了自己写的小工具BCVIEW
 [root@Hadoop1 test]# bcview dname.ibd 16 127 40
 ******************************************************************
 This Tool Is Uesed For Find The Data In Binary format(Hexadecimal)
 Usage:./bcview file blocksize offset cnt-bytes!                 
 file: Is Your File Will To Find Data!                           
 blocksize: Is N kb Block.Eg: 8 Is 8 Kb Blocksize(Oracle)!       
                          Eg: 16 Is 16 Kb Blocksize(Innodb)!     
 offset:Is Every Block Offset Your Want Start!                                   
 cnt-bytes:Is After Offset,How Bytes Your Want Gets!                             
 Edtor QQ:22389860!                                               
 Used gcc version 4.1.2 20080704 (Red Hat 4.1.2-46)               
 ******************************************************************
 ----Current file size is :0.093750 Mb
 ----Current use set blockszie is 16 Kb
 current block:00000000--Offset:00127--cnt bytes:40--data is:00ffffffff0000000000010000000200260000000200260000000000000000ffffffff0000ffffff
 current block:00000001--Offset:00127--cnt bytes:40--data is:00000000000000000000000000000000000000000000000000000000000000000000000000000000
 current block:00000002--Offset:00127--cnt bytes:40--data is:ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff
 current block:00000003--Offset:00127--cnt bytes:40--data is:000001cc6d090000002d5679ab00000d0c011039b4964991ed7c1f87d6324167616f70656e670000
 current block:00000004--Offset:00127--cnt bytes:40--data is:00000000000000000000000000000000000000000000000000000000000000000000000000000000
 current block:00000005--Offset:00127--cnt bytes:40--data is:00000000000000000000000000000000000000000000000000000000000000000000000000000000

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/f3e043773c7e3a9b0aa5473b35e706e3.html