zoukankan      html  css  js  c++  java
  • MySQL的一些小问题

    在建表的时候,总有一些模糊的点让我不得不百度:

    1、金钱字段存储应当选择float、decimal、double?

    应当选择decimal。

    他是以字符串形式存储的,不会损失精度,为啥浮点型的(单精度、双精度)会损失精度呢,看下面的例子:
    定点数如果不写精度和标度,则按照默认值decimal(10,0) 来操作,也就是存储11.1时候,会自动存储为11,(会自动四舍五入)如果11.9则是12

    mysql> create table t1(c1 float(10,2), c3 decimal(10,2)); 
    Query OK, 0 rows affected (0.02 sec)
    
    mysql> insert into t1 values(9876543.21, 9876543.12);                   
    Query OK, 1 row affected (0.00 sec)
    
    mysql> select * from t1;                        
    +----------------+-----------------+
    | c1                | c3                   |
    +----------------+-----------------+
    | 9876543.00 | 9876543.12 | 
    +----------------+------------------+
    2 rows in set (0.00 sec)

    详细解释:https://www.cnblogs.com/gsk99/p/5028817.html (比较复杂) https://www.cnblogs.com/gulibao/p/5416245.html (比较简单但未说明原理,从这里也可以看出如果decimal字段入的是截断后的值会产生警告并且浮点型在入库时候好像与decimal无异

    但是在计算的时候会损失精度

    2、时间戳选取使用varchar、int、timestamp?

    三个都可以, int性能最好但是int的最大数值范围是2038年。时间戳选取timestamp,可以使用默认值为当前时间,并且入库入字符串型的时间,而非时间戳。顺便说一下timestamp比对大小也是直接字符串的

    select count(*) from users where created_at<'2018-08-28 00:00:00' and created_at>='2018-08-01 00:00:00'

    3、varchar和char该当如何选择?

    varchar变长能省空间但是查找慢,char不省空间但是查找快

    4、int(10)和varchar(20)以及float(10,2)、tiny(4)的建表用的数字是干啥的?

     int(10)这个数字设置不会影响该字段能够存储的大小,说是显示时候的长度控制,但是实际试验也没发现,这个不用管了

    varchar和char设置的数字直接决定该字段能存储的字符串的字符数(5.0版本以上的是字符数,以下是字节数),比如char(3)可以存储abc但是无法存储abcd

    float(m,d)之中,m是存储的内容最大整数数量,d是小数精度。比如float(7,4)小数点有四位,那么整数最多3个,也就是123.4567如果存储1234.1123,整数位数有4个,就会报错,小数点会自动四舍五入,decimal也一样

  • 相关阅读:
    访问 IIS 元数据库失败 的解决方法
    【转】IIS网站访问需要输入用户名和密码
    jQuery以Post方式发送请求并获取返回的文件供下载!
    moss2007安装
    货币加逗号 javascript/js
    vs2005 sp1 安装包签名错误解决办法 fid=73863 error 1718
    xpath ignore case query/xpath 不区分大小写
    moss2007 webpart custom property sample
    字符转拼音 javascript pinyin
    moss2007 webpart custom property sample (2) [a simple one, inherit from .net framework webpart]
  • 原文地址:https://www.cnblogs.com/xuweiqiang/p/9809131.html
Copyright © 2011-2022 走看看