2017-04-22 4 views
0

Swift 3.1을 사용하여 외국 및 국제 문자를 SQLite 데이터베이스에 삽입하거나 업데이트 할 때 문제가 있습니다. 그래서 아래에서 UTF8을 추가하려고 시도했지만 오류가 발생했습니다. "예상되는 인수 유형 'OpaquePointer!'에 'string'유형의 값을 변환 할 수 없습니다. ".불투명 포인터 오류 Swift 3.1

나는 어디서 볼지 모르겠다.

func saveDiveDetails (_ dives: Dives) -> Int32 { 
    let diveLog = AppDelegate.getDLDatabase() 

    let diveBuddy = diveBuddyTextField.text ?? "" 
    let diveMaster = diveBuddyTextField.text ?? "" 
    let boatName = diveBuddyTextField.text ?? "" 
    let diveCenter = diveBuddyTextField.text ?? "" 
    let boatOperator = diveBuddyTextField.text ?? "" 
    let city = diveBuddyTextField.text ?? "" 
    let country = diveBuddyTextField.text ?? "" 
    let bodyOfWater = diveBuddyTextField.text ?? "" 
    let tripName = diveBuddyTextField.text ?? "" 
    var statement: OpaquePointer? = nil 

    let update:String = String(format: "UPDATE Dives SET dive_buddy = ?, dive_master = ?, boatName_name = ?, diveCenter_name = ?, boatOperator_name = ?, diveCity_name = ?, bodyOfWater_name = ?, diveCountry_name = ?, tripName_name = ? WHERE id = %d") 

    if(sqlite3_prepare_v2(self.dlDatabase.database, update, -1, &statement, nil) == SQLITE_OK){ 
     sqlite3_bind_text(update, 0, diveBuddy.cString(using: String.Encoding.utf8), -1, SQLITE_TRANSIENT) 
     sqlite3_bind_text(update, 1, diveMaster.cString(using: String.Encoding.utf8), -1, SQLITE_TRANSIENT) 
     sqlite3_bind_text(update, 2, boatName.cString(using: String.Encoding.utf8), -1, SQLITE_TRANSIENT) 
     sqlite3_bind_text(update, 3, diveCenter.cString(using: String.Encoding.utf8), -1, SQLITE_TRANSIENT) 
     sqlite3_bind_text(update, 4, boatOperator.cString(using: String.Encoding.utf8), -1, SQLITE_TRANSIENT) 
     sqlite3_bind_text(update, 5, city.cString(using: String.Encoding.utf8), -1, SQLITE_TRANSIENT) 
     sqlite3_bind_text(update, 6, bodyOfWater.cString(using: String.Encoding.utf8), -1, SQLITE_TRANSIENT) 
     sqlite3_bind_text(update, 7, country.cString(using: String.Encoding.utf8), -1, SQLITE_TRANSIENT) 
     sqlite3_bind_text(update, 8, tripName.cString(using: String.Encoding.utf8), -1, SQLITE_TRANSIENT) 
     sqlite3_bind_int(update, 9, self.diveNumber) 
    } 

    sqlite3_prepare_v2(self.dlDatabase.database, update, -1, &statement, nil) 
    sqlite3_bind_int(statement, 1, Int32(self.diveNumber)); 
    if sqlite3_step(statement) == SQLITE_DONE { 

     print("SQLite saved") 
    } 
    else { 
     let errorMessage = String.init(validatingUTF8: sqlite3_errmsg(dlDatabase.database))! 
     print("update failed! \(errorMessage)") 
    } 
    sqlite3_finalize(statement) 
} 

나는 모든 유형을 검색하지만이 유형의 오류에 대한 참조를 찾을 수 없습니다.

+0

당신은 변환을 위해 너무 String' 클래스'의'.utf8CString' 속성을 사용할 수 있습니다 : https://sqlite.org/c3ref/bind_blob.html

참조하십시오. 컴파일 오류가 발생한 행을 명확히 할 수 있습니까? –

답변