我需要使用数据库中的数据填充数组。当我这样做时,我从我的 pickerView 函数中收到一条错误消息。之前,我将这个数组硬编码如下,现在我希望它来自数据库查询。
var recomendMedsTypes = ["Advil","Aleve", "Ibuprofen","Tylenol"]
我不确定我是否正确设计了我的阵列。该数组由基于以下简单类的函数填充
class Medicine {
var dawa: String
init(dawa: String) {
self.dawa = dawa
}
}
我填充了这个类的一个实例,如下所示
var medname = [Medicine]()
这是填充数组的函数
func readMedName() -> Array<Any>{
//get data from this query
let queryString = "SELECT drugName FROM otc"
//statement pointer
var stmt2:OpaquePointer?
//preparing the query
if sqlite3_prepare(db, queryString, -1, &stmt2, nil) != SQLITE_OK {
let errmsg = String(cString: sqlite3_errmsg(db)!)
print("error preparing read: \(errmsg)")
//return errmsg
}
//go through all the records
while(sqlite3_step(stmt2) == SQLITE_ROW){
let drugname = String(cString: sqlite3_column_text(stmt2,0))
// populate array
medname.append(Medicine(dawa: String(describing: drugname)))
}
return medname
}
这是我尝试从查询中填充数组
var recomendMedsTypes = readMedName()
在pickerView中
func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {
return recomendMedsTypes[row]
}
在这里,我收到错误“无法将 'Any' 类型的返回表达式转换为返回类型 'String?'。如何设计数组和返回查询数据的调用?查询应返回药物列表。