Swift Realm 过滤器问题

问题描述

我有一个 Swift Realm 数据库,我试图找到一个特定的记录,该记录将占用 UIViewController 中的许多标签 - 没有 Tableview。本质上,我想根据由日期和时间组成的字符串变量在数据库搜索记录。字符串格式看起来像这样“Feb19,21-15:47”,但随着每条新记录的添加而变化 - 因此我需要使用字符串变量作为搜索参数。

一旦找到记录,我想抓取与搜索字符串关联的整个记录​​并解析每个字段以填充 VC 上的五个标签。我已经尝试了几个小时来让它发挥作用,但我只是没有得到我需要的结果。

我的问题是:

  1. 如何格式化搜索参数以使用 tempPhotoTitle 查找记录?

  2. 一旦搜索数据库中找到对象属性(tempPhotoTitle),需要使用什么代码获取同一记录/行中的所有关联属性,以便我可以将每个属性绑定到 VC 中的关联标签.

一些注意事项:我确实在名为“id”的每条记录中使用了一个自动更新的主键。使用 Tableview 时,我可以使用 indexPath.row 访问每条记录,但由于我没有使用电视,因此无法使用。 tempPhotoTitle 字符串值是通过 segue 从另一个 VC 提供的。此外,数据库中只有一条记录具有搜索值。这是一些缩写代码,用于提供我的问题的要点。搜索不起作用(解析问题),因此我无法测试剩余的代码。我当然会很感激这方面的一些帮助。非常感谢和沮丧的罗杰

import UIKit
import RealmSwift

 
class Snapshot: Object {
   
    @objc dynamic var id = 0
    @objc dynamic var date: String = ""
    @objc dynamic var cTime: String = ""
    @objc dynamic var airTemp:     String = ""
    @objc dynamic var humidity:    String = ""
    @objc dynamic var photoTitle: String = ""
 
   
    
    
    override class func primaryKey() -> String {
    return "id"
}
 
convenience init( ….)
 
}

 
 
class RecordsVC: UIViewController {
 
    var tempPhotoTitle: String = ""
    var tempImage = UIImage()
   
    
    @IBOutlet weak var eDateHolder: UILabel!
    @IBOutlet weak var eTimeHolder: UILabel!
    @IBOutlet weak var eAirTempHolder: UILabel!
    @IBOutlet weak var eHumidityHolder: UILabel!
    

var editSnapShotItems: Results<Snapshot>?



override func viewDidLoad() {
         super.viewDidLoad()
         queryRecords()

}}

func queryRecords() {
       
        let realm = try! Realm()
       
        let allRecords = realm.objects(editSnapShotItems.self)
       
        let recordResult = allRecords.filter("photoTitle CONTAINS[cd] %@",tempPhotoTitle)
        let recordResults = allRecords.filter(tempPhotoTitle)
       
        for record in recordResults {

        eDateHolder.text = record.date
        eTimeHolder.text = record.cTime
        eAirTempHolder.text = record.airTemp
        eHumidityHolder.text = record.humidity
       
}}}

解决方法

这是这个答案的对象的简化版本

class Snapshot: Object {
    @objc dynamic var date: String = ""
}

如果你创建一个对象

let snap = Snapshot()
snap.date = "Feb19,21-15:47"

然后存储在Realm中

let realm = try! Realm()
realm.write {
   realm.add(snap)
}

然后你想稍后找到

let snapResults = realm.object(Snapshot.self).filter("date == %@","Feb19,21-15:47")
for snap in snapResults {
   print(snap.date)
}

控制台输出将是

Feb19,21-15:47

但是……

以这种格式存储日期存在许多问题。例如,如果您想对 Jan20,21-15:57,Jan21,Feb19,21-15:57 三个日期进行排序,该怎么办。逻辑上它们是按顺序排列的,但因为它们是字符串,所以它们会先按 Feb19 排序(字母表中 F 在 J 之前)。

有多种解决方案:Realm 完全支持 NSDate,因此您可以将它们存储为实际日期,或者如果您真的想使用字符串,请将它们存储为可排序的格式

202102191547

将是 2021 年 2 月 19 日 15:47,确保单个数字用 0 填充。这样可以正确地对它们进行排序、过滤等