所以我开始使用Realm,一切正常,几乎一切正常。我正在使用MultiAutoCompleteTextView来选择一些用户(RealmObject)所以这里是:这是我的过滤器(适配器的内部类)privateclassUserFilterextendsFilter{@OverrideprotectedFilterResultsperformFiltering(CharSequenceconstraint){FilterResultsfilterResults=newFilterResults();if(constraint==null||constraint.length()==0){
我现在经常使用Realm。我很喜欢!但真正烦人的一件事是,在使用copyToRealmOrUpdate时,我无法将主键设置为零。我从服务器取回我的ID。第一个ID为零。所以我的应用程序立即崩溃并显示:Primarykeyconstraintbroken。值已存在:0。如果这是一个不同的数字,它就可以正常工作,但它会在零时崩溃。这是错误还是有人可以帮助我?谢谢! 最佳答案 这里是来自Realm的Christian。0有点问题,因为它也是整数的默认值。这意味着如果您确实将0作为实际值,则使用Realm.createObject()等AP
我有一个RealmResults有一个RealmList我想在每个部分清除的字段。我试过了(包括mRealm.executeTransaction)for(Sectionsection:mSections){section.getEvents().clear();}和IteratorsectionIterator=mSections.iterator();while(sectionIterator.hasNext()){sectionIterator.next().getEvents().clear();}但是Realm抛出了这个异常java.util.ConcurrentModifi
迁移后,我不能再使用Realm.getInstance(context);错误:java.lang.IllegalArgumentException:如果用于打开同一文件,配置不能有不同的架构版本。1对0我看到我必须使用之前创建的配置来进行迁移RealmConfigurationconfig1=newRealmConfiguration.Builder(this).schemaVersion(1).migration(newMigration()).build();现在我必须在所有使用的地方重新创建config1Realm.getInstance(上下文);我过去常常为每个方法添加这个
在RealmJavascript中,可以通过主键创建一个对象,如果它已经存在,则更新现有对象:https://realm.io/docs/javascript/latest/#creating-and-updating-objects-with-primary-keys如何在RealmJava中实现同样的目标?在文档中没有找到这个函数。 最佳答案 HowcanIachievethesameinRealmJava?Didn'tfindthisfunctioninthedocs.有两种方法,1.)copyToRealmOrUpdate(
我有一节这样的公开课openclassNewsResponse(@field:SerializedName("news")valnews:List?=null):RealmObject()像这样的NewsItem类openclassNewsItem(@field:SerializedName("created")valcreated:String?=null,@field:SerializedName("link")vallink:String?=null,@field:SerializedName("description")valdescription:String?=null,@
在我的Android应用程序中,我有一个数据访问层,其中每个数据存储类都有以下属性Realmrealm=Realm.getDefaultInstance();我的问题是当我尝试从不同的线程调用任何数据存储方法时。然后我得到Realmobjectscanonlybeaccessedonthethreadtheywerecreated.我读到我应该在新线程上创建一个新的Realm实例。问题是数据访问层没有线程感知,它不知道它是从main调用还是分离调用,在我看来它会闻到添加逻辑来检查这一点的味道。我正在检查这里的不同问题和github上填写的问题,但我不清楚处理这种情况的官方方法是什么。我
是否可以在android中使用Realm进行“IN”查询?我的意思是,做相当于“SELECTXFROMXWHERExIN(...)?非常感谢您! 最佳答案 官方的IN运算符(自1.2.0起)是这样工作的:publicRealmQueryin(StringfieldName,String[]values){if(values==null||values.length==0){thrownewIllegalArgumentException(EMPTY_VALUES);}beginGroup().equalTo(fieldName,va
我有一个包含大约50k条记录的数据集,我想将其放入Realm数据库中。我不确定如何在Realm中制作此数据库并将其与应用程序bundle在一起,以便文件可以从一开始(安装)就驻留在设备中。 最佳答案 您可以将一个Realm文件放在您的Assets文件夹中,并在您第一次打开应用程序时复制它。这里有一个关于如何做到这一点的例子:https://github.com/realm/realm-java/blob/master/examples/migrationExample/src/main/java/io/realm/examples/
偶尔,我的Gradle同步会失败。我会收到无用的消息,“第3方Gradle插件”可能是原因。如果我打开事件日志,我会看到消息:OutdatedKotlinRuntimeYourversionofKotlinruntimein'Gradle:org.jetbrains.kotlin:kotlin-stdlib:1.2.10@jar'libraryis1.2.10-release-109(1.2.10),whilepluginversionis1.2.51-release-Studio3.1-1.Runtimelibraryshouldbeupdatedtoavoidcompatibili