大佬教程收集整理的这篇文章主要介绍了Android:SQLite一对多设计,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我有2张表与一对多的关系.为了在代码中表示这些,我有2个模型对象. 1st表示主记录,并且具有作为第二对象实例的列表的字段.现在我在模型对象#1中有一个帮助方法,它返回从当前对象生成的ContentValues.使用COntentValues#put重载方法填充一个原始字段是微不足道的,但是我的列表没有运气.所以目前,因为我的第二个表行只是一个单一的字符串值,我生成一个逗号分隔的字符串,然后我重新分配给ContentProvider#insert中的String [].这感觉很幸运,所以也许有人可以提示如何以更清洁的方式做到这一点.
这是一些代码.首先从模型类:
public ContentValues toContentValues() { ContentValues values = new ContentValues(); values.put(ITEM_ID,itemId); values.put(NAME,Name); values.put(TYPES,concat(types)); return values; } private String concat(String[] values) { /* trivial */}
并且这里减少了ContentProvider#insert方法的版本
public Uri insert(Uri uri,ContentValues values) { sqliteDatabase db = dbHelper.getWritableDatabase(); db.begintransaction(); try { // populate types String[] types = ((String)values.get(Offer.TYPES)).split("|"); // we no longer need it values.remove(Offer.TYPES); // first insert row into OFFERS final long rowId = db.insert("offers",Offer.NAME,values); if (rowId > 0 && types != null) { // @L_944_19@ insert all types for the row for (String t : types) { ContentValues type = new ContentValues(8); type.put(Offer.oFFER_ID,rowId); type.put(Offer.TYPE,t); // insert values into second table db.insert("types",Offer.TYPE,typE); } } db.settransactionsuccessful(); return ContentUris.withAppendedId(Offer.CONTENT_URI,rowId); } catch (Exception E) { Log.e(tag,"Failed to insert record",E); } finally { db.endtransaction(); } }
例如,查看ContactsContract内容提供商.联系人可以有很多电子邮件地址,许多电话号码等.完成的方式是在“许多”方面进行插入/更新/删除.要添加新的电话号码,请插入新的电话号码,提供电话号码所在联系人的ID.
如果您有一个没有内容提供者的简单sqlite数据库,那么你也会这样做.关系数据库中的一对多关系是通过在“多”一侧的表上插入/更新/删除来实现的,每个都具有一个外键返回到“一个”侧.
现在,从OO的角度来看,这不是理想的.欢迎您创建ORM风格的包装对象(认为HibernatE),允许您操作“一”一侧的子项集合.一个足够智能的收集类可以转过来同步“许多”表进行匹配.然而,这些并不一定是适当的实施.
以上是大佬教程为你收集整理的Android:SQLite一对多设计全部内容,希望文章能够帮你解决Android:SQLite一对多设计所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。