如何避免mysql的double自动转为科学计数法表示

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何避免mysql的double自动转为科学计数法表示相关的知识,希望对你有一定的参考价值。

参考技术A 如何避免mysql的double自动转为科学计数法表示
Sub FillColumn(fg As vsFlexGrid, ByVal c As Long, ByVal t As String, ByVal s As String)

Dim r&, i&, cnt&
ReDim lst(0) As String

' build list
cnt = 0
i = InStr(s, "|")
While i > 0
lst(cnt) = left(s, i - 1)
s = Mid(s, i + 1)
cnt = cnt + 1
ReDim Preserve lst(cnt) As String
i = InStr(s, "|")
Wend
lst(cnt) = s

' set values
fg.Cell(flexcpText, 0, c) = t
For r = fg.FixedRows To fg.Rows - 1
i = (Rnd() * 1000) Mod (cnt + 1)
fg.Cell(flexcpText, r, c) = lst(i)
Next

' do an autosize
fg.AutoSize c, , , 300
End Sub

FillColumn hfxgrid ""Proposals|Demos|Social|Trips|Projects""本回答被提问者采纳

Java中double类型如何避免显示为科学计数法

//double的金额类型显示为科学计数法
    //这里以String转换double举例
    public static void main(String[] args) 

        //double类型在小数点前位数大于7位时自动转换为科学计数法表示
        String amountStr = "12345678.12";

        double amount = Double.parseDouble(amountStr);
        System.out.println(amount);//1.234567812E7

        BigDecimal bigDecimal = new BigDecimal(amountStr);
        System.out.println(bigDecimal);//12345678.12

        //由此,想要避免科学计数法有以下两种常用方法
        //1、直接使用String不适用double
        //2、使用BigDecimal来作为金额的数据类型(在对应数据库的数据类型时,BigDecimal和double没有不同);private BigDecimal amount;


        //但是直接通过new BigDecimal(amountStr),可能会因为String的值导致报错
        //例如null
        //建议金额为String时,先转double
        String amountStr1 = "12345678.12";

        double amount1 = Double.parseDouble(amountStr);
        BigDecimal bigDecimal1 = new BigDecimal(amount1);
        System.out.println(bigDecimal1);//12345678.12

        String amountStr2 = null;

        double amount2 = Double.parseDouble(amountStr2);
        BigDecimal bigDecimal2 = new BigDecimal(amount2);
        System.out.println(bigDecimal2);//-1.0
    

以上是关于如何避免mysql的double自动转为科学计数法表示的主要内容,如果未能解决你的问题,请参考以下文章

Java中double类型如何避免显示为科学计数法

java中如何让double类型不用科学计数法。

如何使java中double类型不以科学计数法表示

将258.369 double值转为内存表示(科学计数法)

如何使java中double类型不以科学计数法表示

如何使java中double类型不以科学计数法表示