Android:SQLite一对多设计

Android:SQLite一对多设计,第1张

概述任何人都有很好的建议,如何使用ContentProvider实现SQLite的一对多映射?如果你看Uri ContentProvider#insert(Uri,ContentValues),你可以看到它有ContentValues参数包含要插入的数据.问题是在当前的实现中,ContentValues不支持put(String,Object)方法,而class是final,所以我无法扩展它.为什么是 任何人都有很好的建议,如何使用ContentProvIDer实现sqlite的一对多映射?如果你看Uri ContentProvIDer#insert(Uri,ContentValues),你可以看到它有ContentValues参数包含要插入的数据.问题是在当前的实现中,ContentValues不支持put(String,Object)方法,而class是final,所以我无法扩展它.为什么是一个问题?这里是我的设计

我有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) {            // Now 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一对多设计所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1132836.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-30
下一篇 2022-05-30

发表评论

登录后才能评论

评论列表(0条)

保存