MySQLDECIMAL数据类型用于在数据库中存储精确的数值。我们经常将DECIMAL数据类型用于保留准确精确度的列,例如会计系统中的货币数据。

要定义数据类型为DECIMAL的列,请使用以下语法:

column_name DECIMAL(P,D);

在上面的语法中:

  • P是表示有效数字数的精度。P范围为1"htmlcode">
    amount DECIMAL(6,2);

    在此示例中,amount列最多可以存储6位数字,小数位数为2位; 因此,amount列的范围是从-9999.999999.99

    MySQL允许使用以下语法:

    column_name DECIMAL(P);

    这相当于:

    column_name DECIMAL(P,0);

    在这种情况下,列不包含小数部分或小数点。

    此外,我们甚至可以使用以下语法。

    column_name DECIMAL;

    在这种情况下,P的默认值为10

    MySQL DECIMAL存储

    MySQL分别为整数和小数部分分配存储空间。 MySQL使用二进制格式存储DECIMAL值。它将9位数字包装成4个字节。

    对于每个部分,需要4个字节来存储9位数的每个倍数。剩余数字所需的存储如下表所示:

    剩余数字 位 0 0 1–2 1 3–4 2 5–6 3 7-9 4

    例如,DECIMAL(19,9)对于小数部分具有9位数字,对于整数部分具有19位=10位数字,小数部分需要4个字节。 整数部分对于前9位数字需要4个字节,1个剩余字节需要1个字节。DECIMAL(19,9)列总共需要9个字节。

    MySQL DECIMAL数据类型和货币数据

    经常使用DECIMAL数据类型的货币数据,如价格,工资,账户余额等。如果要设计一个处理货币数据的数据库,则可参考以下语法 -

    amount DECIMAL(19,2);

    但是,如果您要遵守公认会计原则(GAAP)规则,则货币栏必须至少包含4位小数,以确保舍入值不超过$0.01。 在这种情况下,应该定义具有4位小数的列,如下所示:

    amount DECIMAL(19,4);

    MySQL DECIMAL数据类型示例

    首先,创建一个名为test_order的新表,其中包含三列:iddescriptioncost

    CREATE TABLE test_order (
     id INT AUTO_INCREMENT PRIMARY KEY,
     description VARCHAR(255),
     cost DECIMAL(19,4) NOT NULL
    );

    第二步,将资料插入test_order表。

    INSERT INTO test_order(description,cost)
    VALUES('Bicycle', 500.34),('Seat',10.23),('Break',5.21);

    第三步,从test_order表查询数据。

    SELECT * from test_order

    查询结果:

    MySQL数据类型DECIMAL用法详解

    第四步,更改cost列以包含ZEROFILL属性。

    ALTER TABLE test_order
    MODIFY cost DECIMAL(19,4) zerofill;

    第五步,再次查询test_order表。

    SELECT * from test_order

    查询结果:

    MySQL数据类型DECIMAL用法详解

    如上所见,在输出值中填充了许多零。

    因为zerofill,当我们插入负值会报错:

    INSERT INTO test_order(description,cost)
    VALUES('test', -100.11);
    <br>提示:
    [SQL]INSERT INTO test_order(description,cost)
    VALUES('test', -100.11)

    [Err] 1264 - Out of range value for column 'cost' at row 1  

    其它插入测试结论:

    当数值在其取值范围之内,小数位多了,则四舍五入后直接截断多出的小数位。

    若数值在其取值范围之外,则直接报Out of range value错误。

标签:
MySQL,DECIMAL

免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
评论“MySQL数据类型DECIMAL用法详解”
暂无“MySQL数据类型DECIMAL用法详解”评论...

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。