Swift 2 中使用谓词的领域搜索数据库
Realm search Database with Predicate in Swift 2
我用 Swift2 编写了一个 (Mac) 应用程序,它应该搜索具有特定主题的教师领域数据库。领域中教师对象的定义如下所示:
class Teacher: Object {
var subjects = List<Subject>()
}
这个class非常复杂所以我删除了一些行...
这是应该过滤具有特定科目的教师数据库并仅返回教师姓名的函数(作为字符串数组:[String]
):
func getAllTeacherNamesForSubject(subject: String) -> [String] {
// Open Database
let realm = openRealmDatabase()
// Or open it this way:
// RLMRealm.setDefaultRealmPath("/Users/name/Data.realm")
// var realm: Realm!
// realm = try! Realm()
// filter the Database with Predicate
let objects = realm.objects(Teacher).filter("!!! Need Help !!!", subject)
// How can I filter the Database? I want to get all the Teachers for that subject
// Make an Array of Objects
let objectsArray = objects.toArray(Teacher) as [Teacher]
// Return
return ???
}
// This is the toArray extension.
// You may need it to use the snippet above
extension Results {
func toArray<T>(ofType: T.Type) -> [T] {
var array = [T]()
for var i = 0; i < count; i++ {
if let result = self[i] as? T {
array.append(result)
}
}
return array
}
}
所以问题是我不知道如何过滤数据库。
有人可以帮我吗?
要过滤与特定值有关系的对象,或者在您的情况下,具有特定名称的主题的教师,您可以使用此谓词进行不区分大小写的搜索:
NSPredicate(format: "ANY subjects.name ==[c] %@", subjectName)
然后将其插入过滤器功能。由于您只想 return 教师姓名,因此您不需要按照建议创建任何扩展,而是使用本机 swift map
方法:
func getAllTeacherNamesForSubject(subjectName: String) -> [String] {
let realm = openRealmDatabase
let predicate = NSPredicate(format: "ANY subjects.name ==[c] %@", subjectName)
return realm.objects(Teacher).filter(predicate).map { [=11=].name }
}
作为参考,您可以找到一个很棒的 cheatsheet on Realm's website 描述支持的谓词语法的完整列表。
我用 Swift2 编写了一个 (Mac) 应用程序,它应该搜索具有特定主题的教师领域数据库。领域中教师对象的定义如下所示:
class Teacher: Object {
var subjects = List<Subject>()
}
这个class非常复杂所以我删除了一些行...
这是应该过滤具有特定科目的教师数据库并仅返回教师姓名的函数(作为字符串数组:[String]
):
func getAllTeacherNamesForSubject(subject: String) -> [String] {
// Open Database
let realm = openRealmDatabase()
// Or open it this way:
// RLMRealm.setDefaultRealmPath("/Users/name/Data.realm")
// var realm: Realm!
// realm = try! Realm()
// filter the Database with Predicate
let objects = realm.objects(Teacher).filter("!!! Need Help !!!", subject)
// How can I filter the Database? I want to get all the Teachers for that subject
// Make an Array of Objects
let objectsArray = objects.toArray(Teacher) as [Teacher]
// Return
return ???
}
// This is the toArray extension.
// You may need it to use the snippet above
extension Results {
func toArray<T>(ofType: T.Type) -> [T] {
var array = [T]()
for var i = 0; i < count; i++ {
if let result = self[i] as? T {
array.append(result)
}
}
return array
}
}
所以问题是我不知道如何过滤数据库。
有人可以帮我吗?
要过滤与特定值有关系的对象,或者在您的情况下,具有特定名称的主题的教师,您可以使用此谓词进行不区分大小写的搜索:
NSPredicate(format: "ANY subjects.name ==[c] %@", subjectName)
然后将其插入过滤器功能。由于您只想 return 教师姓名,因此您不需要按照建议创建任何扩展,而是使用本机 swift map
方法:
func getAllTeacherNamesForSubject(subjectName: String) -> [String] {
let realm = openRealmDatabase
let predicate = NSPredicate(format: "ANY subjects.name ==[c] %@", subjectName)
return realm.objects(Teacher).filter(predicate).map { [=11=].name }
}
作为参考,您可以找到一个很棒的 cheatsheet on Realm's website 描述支持的谓词语法的完整列表。