MySQL中可以用來做價(jià)格的字段一般有float、double、decimal
創(chuàng)新互聯(lián)專注于港口企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站開發(fā),商城網(wǎng)站建設(shè)。港口網(wǎng)站建設(shè)公司,為港口等地區(qū)提供建站服務(wù)。全流程按需求定制制作,專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)
如定義一個(gè)money字段類型為float(9,2),則money字段最大長度為9,整數(shù)位是6位,小數(shù)位是2位。
以下摘自MySQL 5.1參考手冊(cè):
1、FLOAT[(M,D)] [UNSIGNED] [ZEROFILL]
小(單精度)浮點(diǎn)數(shù)。允許的值是-3.402823466E+38到-1.175494351E-38、0和1.175494351E-38到3.402823466E+38。這些是理論限制,基于IEEE標(biāo)準(zhǔn)。實(shí)際的范圍根據(jù)硬件或操作系統(tǒng)的不同可能稍微小些。
M是小數(shù)總位數(shù),D是小數(shù)點(diǎn)后面的位數(shù)。如果M和D被省略,根據(jù)硬件允許的限制來保存值。單精度浮點(diǎn)數(shù)精確到大約7位小數(shù)位。
如果指定UNSIGNED,不允許負(fù)值。
使用浮點(diǎn)數(shù)可能會(huì)遇到意想不到的問題,因?yàn)樵贛ySQL中的所有計(jì)算用雙精度完成。參見A.5.7節(jié),“解決與不匹配行有關(guān)的問題”。
2、DOUBLE[(M,D)] [UNSIGNED] [ZEROFILL]
普通大小(雙精度)浮點(diǎn)數(shù)。允許的值是-1.7976931348623157E+308到-2.2250738585072014E-308、0和2.2250738585072014E-308到 1.7976931348623157E+308。這些是理論限制,基于IEEE標(biāo)準(zhǔn)。實(shí)際的范圍根據(jù)硬件或操作系統(tǒng)的不同可能稍微小些。
M是小數(shù)總位數(shù),D是小數(shù)點(diǎn)后面的位數(shù)。如果M和D被省略,根據(jù)硬件允許的限制來保存值。雙精度浮點(diǎn)數(shù)精確到大約15位小數(shù)位。
如果指定UNSIGNED,不允許負(fù)值。
3、DOUBLE PRECISION[(M,D)] [UNSIGNED] [ZEROFILL], REAL[(M,D)] [UNSIGNED] [ZEROFILL]
為DOUBLE的同義詞。除了:如果SQL服務(wù)器模式包括REAL_AS_FLOAT選項(xiàng),REAL是FLOAT的同義詞而不是DOUBLE的同義詞。
4、FLOAT(p) [UNSIGNED] [ZEROFILL]
浮點(diǎn)數(shù)。p表示精度(以位數(shù)表示),但MySQL只使用該值來確定是否結(jié)果列的數(shù)據(jù)類型為FLOAT或DOUBLE。如果p為從0到24,數(shù)據(jù)類型變?yōu)闆]有M或D值的FLOAT。如果p為從25到53,數(shù)據(jù)類型變?yōu)闆]有M或D值的DOUBLE。結(jié)果列范圍與本節(jié)前面描述的單精度FLOAT或雙精度DOUBLE數(shù)據(jù)類型相同。
FLOAT(p)語法與ODBC兼容。
5、DECIMAL[(M[,D])] [UNSIGNED] [ZEROFILL]
壓縮的“嚴(yán)格”定點(diǎn)數(shù)。M是小數(shù)位數(shù)(精度)的總數(shù),D是小數(shù)點(diǎn)(標(biāo)度)后面的位數(shù)。小數(shù)點(diǎn)和(負(fù)數(shù))的‘-’符號(hào)不包括在M中。如果D是0,則值沒有小數(shù)點(diǎn)或分?jǐn)?shù)部分。DECIMAL整數(shù)最大位數(shù)(M)為65。支持的十進(jìn)制數(shù)的最大位數(shù)(D)是30。如果D被省略, 默認(rèn)是0。如果M被省略, 默認(rèn)是10。
如果指定UNSIGNED,不允許負(fù)值。
所有DECIMAL列的基本計(jì)算(+,-,*,/)用65位精度完成。
6、DEC[(M[,D])] [UNSIGNED] [ZEROFILL], NUMERIC[(M[,D])] [UNSIGNED] [ZEROFILL], FIXED[(M[,D])] [UNSIGNED] [ZEROFILL]
是DECIMAL的同義詞。FIXED同義詞適用于與其它服務(wù)器的兼容性。
mysql為存款金額可以設(shè)置上限20,可以是double(20,2)定義,意思是數(shù)字不會(huì)超過20位,小數(shù)為2位,double是mysql浮點(diǎn)類型數(shù)據(jù)的一種。
在mysql中,金額用“DECIMAL”類型。DECIMAL類型是專門為財(cái)務(wù)相關(guān)問題而設(shè)計(jì)的數(shù)據(jù)類型,能夠解決數(shù)據(jù)的范圍和精度的問題,常用于貨幣數(shù)據(jù),如價(jià)格,工資,帳戶余額等;它實(shí)際上是以字符串的形式存放的,可在定義時(shí)劃定整數(shù)部分以及小數(shù)部分的位數(shù),語法“DECIMAL(M,D)”,參數(shù)M是數(shù)字的最大數(shù)(精度),參數(shù)D是小數(shù)點(diǎn)右側(cè)數(shù)字的數(shù)目(標(biāo)度)。
對(duì)于游戲幣等代幣,一般存儲(chǔ)為int類型是可行的。問題在于越界,int類型長度為11位。
在存儲(chǔ)人民幣相關(guān)的金額的時(shí)候,則只能存儲(chǔ)到9長度的人民幣,也就是說,最大只能存儲(chǔ)999999999,不到10億的數(shù)值,如果業(yè)務(wù)增長很快的話,就會(huì)給自己留下隱患。
Decimal:Decimal為專門為財(cái)務(wù)相關(guān)問題設(shè)計(jì)的數(shù)據(jù)類型。
DECIMAL從MySQL5.1引入,列的聲明語法是DECIMAL(M,D)。在MySQL5.1中,參量的取值范圍如下:M是數(shù)字的最大數(shù)(精度)。其范圍為1~65(在較舊的MySQL版本中,允許的范圍是1~254),M的默認(rèn)值是10。
D是小數(shù)點(diǎn)右側(cè)數(shù)字的數(shù)目(標(biāo)度)。其范圍是0~30,但不得超過M。說明:float占4個(gè)字節(jié),double占8個(gè)字節(jié),decimail(M,D)占M+2個(gè)字節(jié)。
如DECIMAL(5,2)的最大值為9999.99,因?yàn)橛?個(gè)字節(jié)可用。能夠解決數(shù)據(jù)的范圍和精度的問題。
擴(kuò)展資料
MySQL數(shù)據(jù)類型DECIMAL用法:
MySQL?DECIMAL數(shù)據(jù)類型用于在數(shù)據(jù)庫中存儲(chǔ)精確的數(shù)值。我們經(jīng)常將DECIMAL數(shù)據(jù)類型用于保留準(zhǔn)確精確度的列,例如會(huì)計(jì)系統(tǒng)中的貨幣數(shù)據(jù)。
要定義數(shù)據(jù)類型為DECIMAL的列,請(qǐng)使用以下語法:column_name??DECIMAL(P,D);
在上面的語法中:
P是表示有效數(shù)字?jǐn)?shù)的精度。?P范圍為1?65。
D是表示小數(shù)點(diǎn)后的位數(shù)。?D的范圍是0~30。MySQL要求D小于或等于(=)P。
DECIMAL(P,D)表示列可以存儲(chǔ)D位小數(shù)的P位數(shù)。十進(jìn)制列的實(shí)際范圍取決于精度和刻度。
與INT數(shù)據(jù)類型一樣,DECIMAL類型也具有UNSIGNED和ZEROFILL屬性。如果使用UNSIGNED屬性,則DECIMALUNSIGNED的列將不接受負(fù)值。
如果使用ZEROFILL,MySQL將把顯示值填充到0以顯示由列定義指定的寬度。另外,如果我們對(duì)DECIMAL列使用ZEROFILL,MySQL將自動(dòng)將UNSIGNED屬性添加到列。