加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-12 19:00:03 所属栏目:百科 来源:网络整理
导读:我仍然遇到BigDecimal的大问题(眼泪的开始是 here,到目前为止一直持续到 here). 现在我遇到了相反的问题 – 从POJO中的BigDecimal到SQLite表中的REAL. POJO定义为: public class DeliveryItem { private int _id; private String _invoiceNumber; private S
我仍然遇到BigDecimal的大问题(眼泪的开始是 here,到目前为止一直持续到 here).

现在我遇到了相反的问题 – 从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,Byte)不适用
(参数不匹配; 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,"

解决方法

So how can I manipulate the BigDecimal value in the so that it will be accepted by the ContentValues instance?

那么,您可以将call doubleValue() on the BigDecimal降级为双倍,这可以放在ContentValues中(在将其自动装箱为Double之后).或者,您可以将其字符串表示存储在TEXT列中.或者,您可以将unscaledValue()和scale()存储在两个INTEGER列中.

But SQLite’s closest match is REAL

不它不是.

您似乎对在SQLite中存储定价数据感兴趣.在主要搜索引擎上搜索sqlite中存储价格的搜索结果如下:

> SQLite how to use integer for storing price value
> Storing currency values in SQLite3
> https://dba.stackexchange.com/questions/15729/storing-prices-in-sqlite-what-data-type-to-use

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

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读