如何在Real(SQlite)列中存储BigDecimal(Java)值?
我仍然遇到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) 那么我如何操作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," 解决方法
那么,您可以将call
不它不是. 您似乎对在SQLite中存储定价数据感兴趣.在主要搜索引擎上搜索sqlite中存储价格的搜索结果如下: > SQLite how to use integer for storing price value 一致意见是将价值存储为INTEGER列,以最小的单个货币单位(例如,以美元计算的货币价值的美分),或其他适当的其他东西(例如,如果这是最精细的粒度,则为十分之一美分).价格). 然后,您的POJO将保持int值以匹配. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |