当前位置:  开发笔记 > 编程语言 > 正文

如何在Real(SQlite)列中存储BigDecimal(Java)值?

如何解决《如何在Real(SQlite)列中存储BigDecimal(Java)值?》经验,为你挑选了1个好方法。

我仍然遇到BigDecimal的大问题(泪水的痕迹从这里开始,到目前为止一直持续到这里.

现在我遇到了相反的问题 - 从POJO中的BigDecimal到SQLite表中的REAL.

POJO定义为:

public class DeliveryItem {
    private int _id;
    private String _invoiceNumber;
    private String _UPC_PLU;
    private String _vendorItemId;
    private int _packSize;
    private String _description;
    private BigDecimal _cost;
    private BigDecimal _margin;
    private BigDecimal _listPrice;
    private int _departmentNumber;
    private String _subdepartment;
    private String _quantity;

    public void setID(int id) {
        this._id = id;
    }
    . . .

这段代码,试图使数据形状能够发布到SQLite表(其中相应的列是数据类型REAL,SQLite唯一的实数/浮点数据类型):

public long addDeliveryItem(DeliveryItem delItem) {
    long IdAdded = 0;
    ContentValues values = new ContentValues();
    values.put(COLUMN_INVOICENUM, delItem.get_invoiceNumber());
    values.put(COLUMN_UPCPLU, delItem.get_UPC_PLU());
    values.put(COLUMN_VENDORITEMID, delItem.get_vendorItemId());
    values.put(COLUMN_PACKSIZE, delItem.get_packSize());
    values.put(COLUMN_DESCRIPTION, delItem.get_description());
    //values.put(COLUMN_COST, delItem.get_cost());
    //values.put(COLUMN_COST, new BigDecimal(delItem.get_cost()));
    values.put(COLUMN_COST, (Double) delItem.get_cost());
    values.put(COLUMN_MARGIN, delItem.get_margin());
    values.put(COLUMN_LISTPRICE, delItem.get_listPrice());
    values.put(COLUMN_DEPTNUM, delItem.get_departmentNumber());
    values.put(COLUMN_SUBDEPT, delItem.get_subdepartment());
    values.put(COLUMN_QTY, delItem.get_quantity());

    SQLiteDatabase db = this.getWritableDatabase();

    if (db != null) {
        IdAdded = db.insert(TABLE_DELIVERYITEMS, null, values);
    }
    if (db != null) {
        db.close();
    }
    return IdAdded;
}

对于上面的COLUMN_COST行("MARGIN"和"LISTPRICE"列有相同的问题),我得到," 错误:不兼容的类型:BigDecimal无法转换为Double "当我尝试这样做:

values.put(COLUMN_COST, (Double) delItem.get_cost());

...以及注释掉的代码(两行),即:

values.put(COLUMN_COST, delItem.get_cost());

...还有这个:

values.put(COLUMN_COST, new BigDecimal(delItem.get_cost()));

...我得到了," 错误:没有找到适合put(String,BigDecimal)方法的方法ContentValues.put(String,String)不适用(参数不匹配; BigDecimal不能转换为String)方法ContentValues.put(String,字节)不适用(参数不匹配; BigDecimal不能转换为Byte)方法ContentValues.put(String,Short)不适用(参数不匹配; BigDecimal不能转换为Short)方法ContentValues.put(String,Integer)不是适用(参数不匹配; BigDecimal不能转换为Integer)方法ContentValues.put(String,Long)不适用(参数不匹配; BigDecimal不能转换为Long)方法ContentValues.put(String,Float)不适用(参数不匹配) ; BigDecimal无法转换为Float)方法ContentValues.put(String,Double)不适用(参数不匹配; BigDecimal无法转换为Double)方法ContentValues.put(String,Boolean)不适用(参数不匹配; BigDecimal不能 转换为布尔方法)方法ContentValues.put(String,byte [])不适用(参数不匹配; BigDecimal无法转换为byte []) "

那么我如何操作BigDecimal值,以便ContentValues实例接受它?

UPDATE

我可能只需忽略那些val并将DDL更改为以下内容来暂时捏造它:

//+ COLUMN_COST + " REAL,"  + COLUMN_MARGIN + " REAL," + COLUMN_LISTPRICE + " REAL,"
+ COLUMN_COST + " REAL DEFAULT 0,"  + COLUMN_MARGIN + " REAL DEFAULT 0," + COLUMN_LISTPRICE + " REAL DEFAULT 0,"

CommonsWare.. 17

那么我如何操作BigDecimal值,以便ContentValues实例接受它?

嗯,你可以叫doubleValue()BigDecimal给它降级到double,可在去ContentValues(它自动装箱到后Double).或者,您可以将其字符串表示存储在TEXT列中.或者,你可以存储unscaledValue()scale()INTEGER列.

但SQLite最接近的匹配是真实的

不它不是.

您似乎对在SQLite中存储定价数据感兴趣.搜索storing prices in sqlite主要搜索引擎后会出现:

SQLite如何使用整数来存储价格值

在SQLite3中存储货币值

https://dba.stackexchange.com/questions/15729/storing-prices-in-sqlite-what-data-type-to-use

一致意见是将价值存储为一INTEGER列,以最小的单个货币单位(例如,以美元计算的货币价值的美分),或其他适当的其他东西(例如,如果这是价格的最细粒度,则为十分之一的分数) ).

然后,您的POJO将保持int值匹配.



1> CommonsWare..:

那么我如何操作BigDecimal值,以便ContentValues实例接受它?

嗯,你可以叫doubleValue()BigDecimal给它降级到double,可在去ContentValues(它自动装箱到后Double).或者,您可以将其字符串表示存储在TEXT列中.或者,你可以存储unscaledValue()scale()INTEGER列.

但SQLite最接近的匹配是真实的

不它不是.

您似乎对在SQLite中存储定价数据感兴趣.搜索storing prices in sqlite主要搜索引擎后会出现:

SQLite如何使用整数来存储价格值

在SQLite3中存储货币值

https://dba.stackexchange.com/questions/15729/storing-prices-in-sqlite-what-data-type-to-use

一致意见是将价值存储为一INTEGER列,以最小的单个货币单位(例如,以美元计算的货币价值的美分),或其他适当的其他东西(例如,如果这是价格的最细粒度,则为十分之一的分数) ).

然后,您的POJO将保持int值匹配.

推荐阅读
mobiledu2402851203
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有